我试图解析几个值的HTML响应,然后将它们插入sql.我能够获得两个值但是,因为代码包含在foreach语句中,所以我得到它们两次.
这是我的HTML回复
@H_301_8@这是我的代码:
@H_301_8@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,它再次重复.
我的结果如下:
@H_301_8@100.000% (100.000%) 100.000% (100.000%) servicename servicename2 100.000% (100.000%) 100.000% (100.000%) servicename servicename2有没有办法,首先,匹配值,两个,只有他们显示一次?
最佳答案您的第一个foreach遍历整个文档,就像第一个foreach语句中的其他foreach语句一样.
因为有两个表元素与您的XPath表达式匹配@H_301_8@"//table[@class]"你得到了两次答案.如果你有更多的表元素匹配你的XPath表达式,例如7,那么你会得到7次结果.
你想要的是找到表中的表行(tr)内的类“serviceOK”的所有表格分区(td).
一旦你有了这个HtmlNode,你就可以转到上一个包含服务名称的兄弟节点.@H_301_8@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; }