Dopasowywanie węzła na podstawie wartości rodzeństwa do XPath

89

Posiadanie takiego dokumentu 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>

Jak dopasować /records/record/nameposiadanie rodzeństwa /records/record/record-typedo wartości A?

Flavius
źródło

Odpowiedzi:

106

Znalazłem to:

/records/record/name[../record-type/text() = "A"]
Flavius
źródło
10
Łatwiej i jaśniej jest przetestować recordprzed zejściem do name.
kjhughes
58

Zaskakujące jest, że żadna z dotychczasowych odpowiedzi na to stare pytanie nie dostarcza najprostszego rozwiązania XPath.

Ten prosty XPath

/records/record[record-type = "A"]/name

wybiera

<name>svn</name>
<name>blog</name>

zgodnie z prośbą.

kjhughes
źródło
39

Możesz również filtrować element nadrzędny według jego dzieci:

/records/record[record-type[text()='A']]/name

thomasb
źródło
6
To prostsze i bardziej przejrzyste do testu record-typebezpośrednio, bez dodatkowego orzecznika.
kjhughes