1. ホーム
  2. xpath

[解決済み] XPath - 値が等しい要素を選択する

2022-03-08 18:41:34

質問

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 仕様では 文字列の値 は、その要素のすべてのテキストノードの子孫の(文書順の)連結です。 .

これで "strange results" が説明できます。

以下の式を用いると、より良い結果が得られます。

//*[text() = 'qwerty']

上記は、ドキュメント内の少なくとも一つのtext-nodeの子要素が値'qwerty'を持つすべての要素を選択する。

//*[text() = 'qwerty' and not(text()[2])]

上記は、ドキュメント内で text-node の子を1つだけ持ち、その値が 'qwerty' であるすべての要素を選択するものである。