c# – 从Web响应中获取HTML值

我试图解析几个值的HTML响应,然后将它们插入sql.我能够获得两个值但是,因为代码包含在foreach语句中,所以我得到它们两次.

这是我的HTML回复

Nown TimeminedNownmined

这是我的代码

var response = (HttpWebResponse)request.GetResponse();
var stream = response.GetResponseStream();
HtmlDocument doc = new HtmlDocument();
doc.Load(stream);

foreach (HtmlNode node in doc.DocumentNode.SelectNodes("//table[@class]"))
{

    foreach (HtmlNode node2 in node.SelectNodes("//td[@class = 'serviceOK']"))
    {
        var value = node2.InnerText;
    }

    foreach (HtmlNode node3 in node.SelectNodes("//a[contains(@href,'avail.cgi')]"))
    {
        var name = node3.InnerText;
    }

}

name显示了servicename,value显示了类serviceOK,但由于第一个foreach,它再次重复.

我的结果如下:

100.000% (100.000%)
100.000% (100.000%)
servicename
servicename2
100.000% (100.000%)
100.000% (100.000%)
servicename
servicename2

有没有办法,首先,匹配值,两个,只有他们显示一次?

最佳答案
您的第一个foreach遍历整个文档,就像第一个foreach语句中的其他foreach语句一样.
因为有两个表元素与您的XPath表达式匹配

"//table[@class]"

你得到了两次答案.如果你有更多的表元素匹配你的XPath表达式,例如7,那么你会得到7次结果.
你想要的是找到表中的表行(tr)内的类“serviceOK”的所有表格分区(td).
一旦你有了这个HtmlNode,你就可以转到上一个包含服务名称的兄弟节点.

var response = (HttpWebResponse)request.GetResponse();
var stream = response.GetResponseStream();
HtmlDocument doc = new HtmlDocument();
doc.Load(stream);

foreach (HtmlNode serviceOkNode in doc.DocumentNode.SelectNodes("//table[@class]/tr/td[@class = 'serviceOK']"))
{
    HtmlNode serviceNameNode = serviceOkNode.PrevIoUsSibling;
    var value = serviceOkNode.InnerText;
    var name = serviceNameNode.InnerText;
}

相关文章

vue阻止冒泡事件 阻止点击事件的执行 <div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些