xml beispiele - Übereinstimmen eines Knotens basierend auf einem Geschwisterwert mit XPath




tester examples (5)

Ein XML-Dokument wie folgt haben:

<?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>

Wie passt man alle / records / record / name zusammen , die als Geschwister / records / record / record-type den Wert "A" haben?


Answers

Fand es:

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

/records/record[record-type='A']

Überraschenderweise bietet keine der Antworten auf diese alte Frage die einfachste XPath-Lösung.

Dieser einfache XPath

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

wählt aus

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

wie gewünscht.


Sie können ein übergeordnetes Element auch nach seinen untergeordneten Elementen filtern:

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


Ich glaube, dass dieser XPath-Ausdruck die gewünschten Knoten auswählt:

//table[@class="header_completed"]/
    following-sibling::table[@align="center"][1]/
        preceding-sibling::table[
            preceding-sibling::table[@class="header_completed"]
        ]

Zuerst navigiere ich mit @class="header_completed" zur table .

Von dort wähle ich die erste folgende Geschwister-Tabelle mit @align="center" .

Von dort wähle ich alle vorhergehenden Geschwister-Tabellen aus, die ein vorhergehendes Geschwister haben, welches die Tabelle mit @class="header_completed" .





xml xpath