Como seleciono um nó XML com base em seu conteúdo?
Pergunta
Como posso usar XPath para selecionar um nó XML com base em seu conteúdo?
Se eu, por exemplo.tenho o seguinte xml e quero selecionar o nó <author> que contém Ritchie para obter o nome completo do autor:
<books>
<book isbn='0131103628'>
<title>The C Programming Language</title>
<authors>
<author>Ritchie, Dennis M.</author>
<author>Kernighan, Brian W.</author>
</authors>
</book>
<book isbn='1590593898'>
<title>Joel on Software</title>
<authors>
<author>Spolsky, Joel</author>
</authors>
</book>
</books>
Solução
/books/book/authors/author[contains(., 'Ritchie')]
ou
//author[contains(., 'Ritchie')]
Outras dicas
O XPath para isso é:
/books/book/authors/author[contains(., 'Ritchie')]
Em C#, o código a seguir retornaria "Ritchie, Dennis M.":
xmlDoc.SelectSingleNode("/books/book/authors/author[contains(., 'Ritchie')]").InnerText;
//author[contains(text(), 'Ritchie')]
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow