所以我正在尝试用xpath.Here解析一些html,这就是我的页面的样子
<area id="a_0_0" alt="asd">
<area id="a_0_1" alt="asd">
<area id="a_1_0" alt="asd">
<area id="a_1_1" alt="asd">
那么用xpath解析它是可能的吗?或者我需要使用其他东西?我对xpath还不太熟悉,下面是我尝试过的内容
doc.DocumentNode.SelectSingleNode("//area[@id='a_0_0']").Attributes["alt"].Value;//this is works
doc.DocumentNode.SelectSingleNode("//area[@id='a_0_[position() >=0 and position() <=1]']").Attributes["alt"].Value
doc.DocumentNode.SelectSingleNode("//area[@id='a_[position() >=0 and position() <=1]']_[position() >=0 and position() <=1]']").Attributes["alt"].Value
发布于 2019-05-31 13:18:21
这是一个简单的解决方案。
var nodes = doc.DocumentNode.SelectNodes("//area[contains('a_0_0,a_0_1,a_1_0,a_1_1',id)]")
foreach (var node in nodes)
{
// node.Attributes["alt"].Value
}
你也可以使用下面的方法来获取所有具有alt属性的区域节点。
var nodes = doc.DocumentNode.SelectNodes("//area[@alt]");
要获取所有以a_
开头的区域节点,请使用以下命令。
var nodes = doc.DocumentNode.SelectNodes("//area[starts-with(@id,'a_')][@alt]);
发布于 2019-05-30 08:52:30
您可以将xml解析为XDocument,并从linq中获益。
XDocument.Parse(xmlstring)
https://stackoverflow.com/questions/56370109
复制相似问题