ใน 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 ของฉันเพื่อให้ได้ผลลัพธ์ที่คาดหวังมากขึ้น
. =
แตกต่างtext() =
XPath ดูว่าโหนดข้อความที่ตรงกันแตกต่างจากค่าสตริงที่ตรงกันเพื่อเรียนรู้สาเหตุ