Cómo obtener todos los nodos secundarios con html agility pack y xpath

html-agility-pack xml xpath

Pregunta

Tengo un documento XML que estoy intentando analizar con HTML Agility Pack usando XPath. Este es mi código para obtener los elementos:

HtmlDocument htmldoc = new HtmlDocument();
htmldoc.Load(fileName);
HtmlNodeCollection nodes = htmldoc.DocumentNode.SelectNodes("feed/l");

Este es mi documento XML

<?xml version="1.0" encoding="UTF-8"?>
<feed>
<tm>5701</tm>
<tp>1141</tp>
<pnr>1</pnr>
<l type="TEXT">
<ca>
<c id="21">JA</c>
</ca>
<pts>
<pt id="5">DO</pt>
</pts>
<od>MA 99</od>
<osd>2014-02-21</osd>
<od>2014-02-22</od>
<cu>url</cu>
<ip>ip</ip>
<ai>3184</ai>
<an>com</an>
<n id="1">US n</n>
</l>
</feed>

Estoy tratando de obtener todos los nodos que son hijos de l y sus hijos, pero mi XPath devuelve nodos con l como una colección, pero los hijos son nulos. Los nodos que busco agrupados por l son estos

 <ca>
<c id="21">JA</c>
</ca>
<pts>
<pt id="5">DO</pt>
</pts>
<od>MA 99</od>
<osd>2014-02-21</osd>
<od>2014-02-22</od>
<cu>url</cu>
<ip>ip</ip>
<ai>3184</ai>
<an>com</an>
<n id="1">US n</n>

Pero no hay niños. Por favor, ayuda, mi XPath parece ser correcta.

Respuesta popular

Tu XPath debería ser

feed/l/*

Como quieras el elemento hijos de l . Así que en tu código debería estar

HtmlNodeCollection nodes = htmldoc.DocumentNode.SelectNodes("feed/l/*");


Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué
Licencia bajo: CC-BY-SA with attribution
No afiliado con Stack Overflow
¿Es esto KB legal? Sí, aprende por qué