Xpathで、特定の値に等しい要素を選択したいと思います。
サンプルXMLデータ:
<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>
次に、XPathを使用します。
//ccc[.='qwerty']
期待どおりの正しい結果が得られます。
Name Value
ccc qwerty
次に、XPathを使用します。
//aaa[.='qwerty']
私が取得予期しない結果を:
Name Value
aaa
aaa qwerty
そして私が特に興味を持っているのは、その値を持つ要素をどのように選択するかです
XPath:
//*[.='qwerty']
非常に奇妙な予期しない結果が得られます。
Name Value
aaa
bbb
ddd qwerty
bbb qwerty
aaa qwerty
ccc qwerty
誰かがこれらの結果を説明できますか、より期待される結果を得るためにXPath式を修正する方法はありますか?
. =
はXPath とは異なるためtext() =
です。理由については、一致するテキストノードが一致する文字列値と異なるのを確認してください。