如何在没有特定属性的所有元素上使用XPath进行过滤

时间:2009-05-01 16:27:06

标签: xml xpath

我的XPath有点生疏...假设我有这个简单的XML文件:

<?xml version="1.0" encoding="utf-8" ?>
<States xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<States>
<StateProvince name="ALABAMA" abbrev="AL" />
....
<StateProvince name="AMERICAN SAMOA" abbrev="AS" territory="true"  />
</States>
</States>

我想运行一个简单的XPath查询来解析所有的真实状态(所以不要拉入territory = true的状态)。我试过\ StateProvince [@territory!='true']但是我得到了零。其他变化似乎失败了。这似乎应该很简单,但找不到我想要的东西。

任何帮助表示感谢。

3 个答案:

答案 0 :(得分:31)

选择所需元素的一个XPath表达式

<强> /*/States/StateProvince[not(@territory='true')]

请注意 必须尽可能避免 // 缩写,因为它会导致整个文档(以上下文节点为根的子树)扫描

上述XPath表达式考虑到最初提供的结构,避免使用 // 缩写 XML文档。

只有当XML文档的结构完全未知时(并且XPath表达式打算用于许多结构未知的XML文档),才应使用 // 缩写被视为

答案 1 :(得分:6)

你非常接近:

//StateProvince[not(@territory) or @territory != 'true']

应该得到你想要的结果。

答案 2 :(得分:3)

这应该有效:

//StateProvince[not(@territory='true')]