test.xml的一部分
<tr class="a">
<td align="left" nowrap="true">desc1</td>
<td align="left">desc2</td>
<td>desc3</td>
<td align="left">desc4</td>
<td align="left">desc5</td>
<td>desc6</td>
<td>desc7</td>
<td>desc8</td>
<td class="nr">desc9</td>
</tr>//创建XpathNavigator,获取td内部的最后一个值,即desc9
> HtmlDocument document = new HtmlDocument();
document.Load(Server.MapPath("test.xml"));
XPathNavigator xPathNavigator = document.CreateNavigator();
object o = xPathNavigator.Evaluate("/table[1]/tbody[1]/tr[2]/td[9]");调试器显示可以按如下方式计算该值,这非常麻烦。
((HtmlAgilityPack.HtmlNodeNavigator)((new System.Linq.SystemCore_EnumerableDebugView(((MS.Internal.Xml.XPath.XPathSelectionIterator)(o)))).Items[0])).Value访问desc9的最佳方式是什么?
发布于 2011-08-22 21:23:12
我没有使用过XPathNavigator,但是这里有一个类似的解决方案,使用SelectNodes/SelectSingleNode风格和HTML Agility Pack。
string xPathSearch = "/table[1]/tbody[1]/tr[2]";
HtmlNode tableRow = doc.DocumentNode.SelectSingleNode(xPathSearch);
string description9 = tableRow.ChildNodes[9].InnerText;或
string xPathSearch = "/table[1]/tbody[1]/tr[2]/td[9]";
HtmlNode tableColumn = doc.DocumentNode.SelectSingleNode(xPathSearch);
string description9 = tableColumn.InnerText;仅供参考-关于HTML Agility包的最好的文档似乎是源代码中包含的示例。不确定为什么不在文档中单独下载。
发布于 2011-08-22 21:06:49
如下所示:
/table[1]/tbody[1]/tr[@class="a"]/td[last()]看一看XPath Syntax
发布于 2011-08-22 21:23:30
我认为你做错了这件事。
我相信你所需要做的就是:
document.DocumentNode.SelectSingleNode("/table[1]/tbody[1]/tr[2]/td[9]");我找不到可以链接到您的文档的在线副本,但您可以查看http://htmlagilitypack.codeplex.com/releases/view/44954上的文档以了解更多详细信息。
另外,如果您只是在阅读XML,那么您使用html敏捷包有什么原因吗?或者只有您的测试文件才是有效的XML?
https://stackoverflow.com/questions/7142661
复制相似问题