C#使用xpath找到一个节点

Xpath这是非常强大。但对比是一个更复杂的技术,希望上面去博客园特别想看看一些专业职位。下面是一些简单Xpath的语法和示例,给你参考

<?xml version="1.0" encoding="ISO-8859-1"?>

<catalog>

<cd country="USA">

<title>Empire Burlesque</title>

<artist>Bob Dylan</artist>

<price>10.90</price>

</cd>

<cd country="UK">

<title>Hide your heart</title>

<artist>Bonnie Tyler</artist>

<price>9.90</price>

</cd>

<cd country="USA">

<title>Greatest Hits</title>

<artist>Dolly Parton</artist>

<price>9.90</price>

</cd>

</catalog>

定位节点

XML是树状结构,类似档案系统内数据夹的结构。XPath也类似档案系统的路径命名方式。只是XPath 是一种模式(Pattern)。能够选出 XML档案中,路径符合某个模式的全部节点出来。比如要选catalog底下的cd中全部price元素能够用:

/catalog/cd/price

假设XPath的开头是一个斜线(/)代表这是绝对路径。假设开头是两个斜线(//)表示文件里全部符合模式的元素都会被选出来。即使是处于树中不同的层级也会被选出来。

下面的语法会选出文件里全部叫做cd的元素(在树中的不论什么层级都会被选出来):

//cd

选择未知的元素

使用星号(Wildcards,*)能够选择未知的元素。以下这个语法会选出/catalog/cd 的全部子元素:

/catalog/cd/*

下面的语法会选出全部catalog的子元素中,包括有price作为子元素的元素。

/catalog/*/price

下面的语法会选出有两层父节点,叫做price的全部元素。

/*/*/price

下面的语法会选择出文件里的全部元素。

//*

要注意的是。想要存取不分层级的元素,XPath语法必须以两个斜线开头(//)。想要存取未知元素才用星号(*)。星号仅仅能代表未知名称的元素,不能代表未知层级的元素。

选择分支

使用中括号能够选择分支。

下面的语法从catalog的子元素中取出第一个叫做cd的元素。

XPath的定义中没有第0元素这样的东西。

/catalog/cd[1]

下面语法选择catalog中的最后一个cd元素:(XPathj并未定义 first() 这样的函式喔,用上例的 [1]就能够取出第一个元素。

/catalog/cd[last()]

下面语法选出含有price子元素的全部/catalog/cd元素。

/catalog/cd[price]

下面语法选出price元素的值等于10.90的全部/catalog/cd元素

/catalog/cd[price=10.90]

下面语法选出price元素的值等于10.90的全部/catalog/cd元素 的price元素

/catalog/cd[price=10.90]/price

选择一个以上的路径

使用Or操作数(|)就能够选择一个以上的路径。比如:

/catalog/cd/title | catalog/cd/artist

选择全部title以及artist元素

//title | //artist

选择全部title以及artist以及price元素

//title | //artist | //price

选择属性

在XPath中,除了选择元素以外。也能够选择属性。

属性都是以@开头。比如选择文件里全部叫做country的属性:

//@country

选择全部含有country这个属性的cd元素:

//cd[@country]

下面语法选择出含有属性的全部cd元素

//cd[@*]

下面语法选择出country属性值为UK的cd元素

//cd[@country=‘UK‘]

针对多个属性的查找:

Books/book[@author=‘John‘ and @year=‘2009‘ and @language=‘En‘]

版权声明:本文博客原创文章,博客,未经同意,不得转载。

时间: 2024-08-24 20:06:29

C#使用xpath找到一个节点的相关文章

在二叉树中找到一个节点的后继节点

题目思路 题目来源 C++代码实现 /* struct TreeLinkNode { int val; struct TreeLinkNode *left; struct TreeLinkNode *right; struct TreeLinkNode *next; TreeLinkNode(int x) :val(x), left(NULL), right(NULL), next(NULL) { } }; */ class Solution { public: TreeLinkNode* Ge

58 - 二叉树的中序遍历的下一个节点

题目: 给定一棵二叉树和其中的一个节点,如何找出中序遍历顺序的下一个节点?树中的节点除了由两个分别指向左右节点的指针外,还有一个指向父节点的指针. 中序遍历:先访问当前节点的左子树,再访问当前节点本身,最后访问当前节点的右子树. 因此: 如果给定节点有右子树,则下一个节点是它的右子节点: 如果给定节点没有右子树,需要向上找到一个祖父节点(它是自己父节点的左节点),该祖父节点的父节点就是下一个节点.如果没有找到,返回NULL. 中序遍历顺序为:428591637 如上图中,给定节点9,则无右节点,

剑指offer第二版面试题7:二叉树的下一个节点(JAVA版本)

题目:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 分析: 根据中序遍历的特点,要找到一个节点的下一个节点无非就是三种情况: 1.有右子树,这时只需要把其右孩子作为下一个遍历的(并不是要找的)节点,然后沿着该节点的左子树(如果有的话)出发,直到遇到叶子节点,那么该叶子节点就是其下一个要找的节点: 2.没有右子树,则判断该节点是否是其父节点的左孩子,如果是则其下一个要找的节点是其父节点: 3.如果不是其父节点

用XPath精确定位节点元素&amp;selenium使用Xpath定位之完整篇

在利用XSL进行转换的过程中,匹配的概念非常重要.在模板声明语句 xsl:template match = ""和模板应用语句xsl:apply-templates select = "" 中,用引号括起来的部分必须能够精确地定位节点.具体的定位方法则在XPath中给出. 之所以要在XSL中引入XPath的概念,目的就是为了在匹配XML文档结构树时能够准确地找到某一个节点元素.可以把XPath比作文件管理路 径:通过文件管理路径,可以按照一定的规则查找到所需要的文件

第一百二十六节,JavaScript,XPath操作xml节点

第一百二十六节,JavaScript,XPath操作xml节点 学习要点: 1.IE中的XPath 2.W3C中的XPath 3.XPath跨浏览器兼容 XPath是一种节点查找手段,对比之前使用标准DOM去查找XML中的节点方式,大大降低了查找难度,方便开发者使用.但是,DOM3级以前的标准并没有就XPath做出规范:直到DOM3在首次推荐到标准规范行列.大部分浏览器实现了这个标准,IE则以自己的方式实现了XPath. 一.IE中的XPath 在IE8及之前的浏览器,XPath是采用内置基于A

LeetCode OJ:Populating Next Right Pointers in Each Node II(指出每一个节点的下一个右侧节点II)

Follow up for problem "Populating Next Right Pointers in Each Node". What if the given tree could be any binary tree? Would your previous solution still work? Note: You may only use constant extra space. For example,Given the following binary tr

C#使用xpath查找xml节点信息

Xpath是功能很强大的,但是也是相对比较复杂的一门技术,最好还是到博客园上面去专门找一些专业的帖子来看一看,下面是一些简单的Xpath语法和一个实例,提供给你参考一下. xml示例: <?xml version="1.0" encoding="utf-8" ?> <roles> <role order="1"> <roleId>1</roleId> <roleName>一般

用XPath查找HTML节点或元素

虽然JQ和JS都能很方便的查找包含了ID及类名的元素,但某些情况下,我们需要查找一些不包含类名.ID的元素或节点,就需要XPath来帮忙了. XPath虽然是被设计用来搜寻XML文档的,不过它也能很好的在HTML文档中工作,并且大部分浏览器也支持通过XPath来查询节点. XPath既然叫Path,就是以路径的形式来指定元素.关于XPath的语法,这里不多赘述,请自行查询相关资料. XPath的查询函数,在IE中与其他浏览器(Chrome.Firefox.Opear等)是不一样的,所以如果你的网

二叉树中删除一个节点

二叉树的删除可以算是二叉树最为复杂的操作,删除的时候要考虑到很多种情况: 1.被删除的节点是叶子节点 2.被删除的节点只有左孩子节点 3.被删除的节点只有右孩子节点 4.被删除的有两个孩子节点 所以在删除的时候,这4种情况都必须考虑进去,并且这4中情况之下,还会有细的划分,下面就细说怎么删除. 在二叉树中想要删除一个节点,首先需要找到这个节点,由于二叉树在插入节点的时候会遵循一个原则,就是利用节点的值来判断 节点将被插入的位置(或者给节点加一个key,用key来判断).从根节点开始往下走,比当前