In Xpath möchte ich Elemente auswählen, die einem bestimmten Wert entsprechen.
XML-Beispieldaten:
<aaa id="11" >
<aaa id="21" >
<aaa id="31" ></aaa>
<bbb id="32" >
<aaa id="41" ></aaa>
<bbb id="42" ></bbb>
<ccc id="43" ></ccc>
<ddd id="44" >qwerty</ddd>
<ddd id="45" ></ddd>
<ddd id="46" ></ddd>
</bbb>
</aaa>
<bbb id="22" >
<aaa id="33" >qwerty</aaa>
<bbb id="34" ></bbb>
<ccc id="35" ></ccc>
<ddd id="36" ></ddd>
<ddd id="37" ></ddd>
<ddd id="38" ></ddd>
</bbb>
<ccc id="23" >qwerty</ccc>
<ccc id="24" ></ccc>
</aaa>
Verwenden Sie jetzt den XPath:
//ccc[.='qwerty']
Ich erhalte die richtigen erwarteten Ergebnisse:
Name Value
ccc qwerty
Verwenden Sie jetzt den XPath:
//aaa[.='qwerty']
Ich erhalte unerwartete Ergebnisse:
Name Value
aaa
aaa qwerty
nd was mich besonders interessiert, ist die Auswahl eines Elements mit diesem Wert
XPath:
//*[.='qwerty']
Ich bekomme sehr seltsame unerwartete Ergebnisse:
Name Value
aaa
bbb
ddd qwerty
bbb qwerty
aaa qwerty
ccc qwerty
Kann jemand diese Ergebnisse erklären und wie man meine XPath-Ausdrücke repariert, um mehr erwartete Ergebnisse zu erzielen?
Die XPath-Spezifikation definiert den Zeichenfolgenwert eines Elements als die Verkettung (in Dokumentreihenfolge) aller seiner Textknoten-Nachkommen..
Dies erklärt die "seltsamen Ergebnisse".
Mit den folgenden Ausdrücken können "bessere" Ergebnisse erzielt werden:
//*[text() = 'qwerty']
Mit dem obigen Befehl wird jedes Element im Dokument ausgewählt, das mindestens einen untergeordneten Textknoten mit dem Wert "qwerty" enthält.
//*[text() = 'qwerty' and not(text()[2])]
Mit dem obigen Befehl wird jedes Element im Dokument ausgewählt, das nur einen untergeordneten Textknoten hat. Der Wert lautet: 'qwerty'.
Versuchen
//*[text()='qwerty']
weil .
ist Ihr aktuelles Element