给定这个XML, XPath返回所有prop属性包含Foo的元素(前三个节点):
<bla>
<a prop="Foo1"/>
<a prop="Foo2"/>
<a prop="3Foo"/>
<a prop="Bar"/>
</bla>
给定这个XML, XPath返回所有prop属性包含Foo的元素(前三个节点):
<bla>
<a prop="Foo1"/>
<a prop="Foo2"/>
<a prop="3Foo"/>
<a prop="Bar"/>
</bla>
//a[contains(@prop,'Foo')]
如果我使用这个XML返回结果,则有效。
<bla>
<a prop="Foo1">a</a>
<a prop="Foo2">b</a>
<a prop="3Foo">c</a>
<a prop="Bar">a</a>
</bla>
编辑: 另一件需要注意的事情是,虽然上面的XPath将返回特定xml的正确答案,但如果您希望保证只获得元素“bla”中的“a”元素,那么您也应该像其他人提到的那样使用
/bla/a[contains(@prop,'Foo')]
这将搜索整个xml文档中的所有“a”元素,不管它们嵌套在“blah”元素中
//a[contains(@prop,'Foo')]
我添加这个是为了彻底和stackoverflow的精神。:)
descendant-or-self::*[contains(@prop,'Foo')]
Or:
/bla/a[contains(@prop,'Foo')]
Or:
/bla/a[position() <= 3]
切割:
descendant-or-self::
Axis—搜索下面的每个节点和节点本身。通常用this比用//更好。我遇到过一些实现,其中//表示任意位置(根节点的从属或self)。另一个使用默认轴。
* or /bla/a
Tag -通配符匹配,/bla/a是绝对路径。
[contains(@prop,'Foo')] or [position() <= 3]
[]内的条件。@prop是attribute::prop的简写,因为attribute是另一个搜索轴。或者,您可以使用position()函数选择前3个。
这个XPath将给出所有具有包含'Foo'属性的节点,而不管节点名称或属性名称:
//attribute::*[contains(., 'Foo')]/..
当然,如果您更感兴趣的是属性本身的内容,而不一定是它们的父节点,只需删除/..
//attribute::*[contains(., 'Foo')]