No Xpath, estou querendo selecionar elementos que igualam um valor específico.
Dados XML de amostra:
<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>
Agora, usando o XPath:
//ccc[.='qwerty']
Eu obtenho os resultados esperados e corretos :
Name Value
ccc qwerty
Agora, usando o XPath:
//aaa[.='qwerty']
Recebo inesperados resultados:
Name Value
aaa
aaa qwerty
E o que estou particularmente interessado é em como selecionar qualquer elemento com esse valor
XPath:
//*[.='qwerty']
Obtenho resultados inesperados muito estranhos :
Name Value
aaa
bbb
ddd qwerty
bbb qwerty
aaa qwerty
ccc qwerty
Alguém pode explicar esses resultados e como corrigir minhas expressões XPath para obter os resultados mais esperados?
. =
é diferente de XPathtext() =
. Ver nós de texto correspondentes é diferente de valores de string correspondentes para saber por quê.Respostas:
A especificação XPath. define o valor da string de um elemento como a concatenação (na ordem do documento) de todos os seus descendentes de nó de texto .
Isso explica os "resultados estranhos".
Resultados "melhores" podem ser obtidos usando as expressões abaixo:
O item acima seleciona cada elemento no documento que tem pelo menos um filho de nó de texto com o valor 'qwerty'.
O item acima seleciona cada elemento no documento que tem apenas um filho de nó de texto e seu valor é: 'qwerty'.
fonte
text()
é um dos testes de nó possíveis no XPath, significando "este é um nó de texto?". Outros nodetests sãocomment()
,processing-instruction()
ou apenasnode()
.Experimentar
//*[text()='qwerty']
porque.
é o seu elemento atualfonte