XPath-выбор элементов, равных значению



в 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, чтобы получить более ожидаемые результаты?

655   2  

2 ответов:

спецификация XPath. определяет строковое значение элемента как конкатенация (в порядке документа) всех его потомков текстового узла.

Это объясняет "странные результаты".

"лучшие" результаты могут быть получены с помощью следующих выражений:

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

выше выбирается каждый элемент в документе, который имеет по крайней мере один дочерний текстовый узел со значением 'qwerty'.

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

выше выбирает каждый элемент в документе, который имеет только один дочерний текстовый узел и его значение: 'qwerty'.

попробовать

//*[text()='qwerty'], потому что . ваш настоящее элемент

Comments

    Ничего не найдено.