Sri*_*ine 1 html html-table html-agility-pack
我有一个html表结构.我需要获得<td>最终<tr>标签中第一个值的值.这是我的表格结构.我需要从以下函数getFinalNodeValue得到的值是" 3 ".
<table id="test">
<tr>
<td>ID</td>
<td>Name</td>
<td>Age</td>
</tr>
<tr>
<td>1</td>
<td>Yasoda</td>
<td>21</td>
</tr>
<tr>
<td>2</td>
<td>Samantha</td>
<td>25</td>
</tr>
<tr>
<td>3</td>
<td>Sajee</td>
<td>26</td>
</tr>
</table>
Run Code Online (Sandbox Code Playgroud)
这是我用HtmlAgilityPack编写的代码.
public String getFinalNodeValue(String URL)
{
var webGet = new HtmlWeb();
var pageSource = webGet.Load(URL);
var table = pageSource.DocumentNode.SelectSingleNode("//table[@id='test']//tr[1]");
string id = null;
IEnumerable<HtmlNode> trNodes = table.DescendantsAndSelf();
foreach (var currentItem in trNodes)
{
if (currentItem == trNodes.Last())
{
IEnumerable<HtmlNode> tdNodes = currentItem.Descendants();
foreach (var x in tdNodes)
{
if(x == tdNodes.First())
{
id = x.InnerText;
}
else
{
break;
}
}
}
else
{
continue;
}
}
return id;
}
Run Code Online (Sandbox Code Playgroud)
该方法不返回值.任何帮助都非常感谢.
这应该这样做:
HtmlDocument doc = new HtmlDocument();
doc.Load(MyHtmlFile);
HtmlNode node = doc.DocumentNode.SelectSingleNode("//table[@id='test']/tr[last()]/td");
Console.WriteLine(node.InnerText);
Run Code Online (Sandbox Code Playgroud)
注意XPATH last()函数的用法
| 归档时间: |
|
| 查看次数: |
3544 次 |
| 最近记录: |