拥有这样的XML文档:
<?xml version="1.0" encoding="UTF-8"?>
<records type="array">
<record>
<name>svn</name>
<record-type>A</record-type>
<ttl type="integer">86400</ttl>
<zone-id type="integer">69075</zone-id>
<aux type="integer">0</aux>
<id type="integer">xxx</id>
<active>Y</active>
<data>xxx.xxx.xxx.xxx</data>
</record>
<record>
<name>domain.tld.</name>
<record-type>NS</record-type>
<ttl type="integer">86400</ttl>
<zone-id type="integer">xxx</zone-id>
<aux type="integer">0</aux>
<id type="integer">xxx</id>
<active>Y</active>
<data>domain.tld.</data>
</record>
<record>
<name>blog</name>
<record-type>A</record-type>
<ttl type="integer">86400</ttl>
<zone-id type="integer">xxx</zone-id>
<aux type="integer">0</aux>
<id type="integer">xxx</id>
<active>Y</active>
<data>xxx.xxx.xxx.xxx</data>
</record>
</records>
如何将具有兄弟/记录/记录/记录类型的所有/记录/记录/ 名称与值“A”匹配?
答案 0 :(得分:101)
找到它:
/records/record/name[../record-type/text() = "A"]
答案 1 :(得分:43)
令人惊讶的是,迄今为止在这个旧问题上的答案都没有提供最简单的 XPath解决方案。
这个简单的XPath
/records/record[record-type = "A"]/name
<强>选择强>
<name>svn</name>
<name>blog</name>
根据要求。
答案 2 :(得分:39)
您还可以通过子元素过滤父元素:
/records/record[record-type[text()='A']]/name