我正在使用HTMLAgilityPack。我有这样的事情:
<div class="address">
<h3>Postadress</h3>
<div class="box-address">Box 27 </div>
<div class="post-address">
16493 KISTA
</div>
</div>
问题是还有其他<div class="address">
个。
所以我必须找到一个<h3>
孩子的文字“Postaddress”。
我需要提取的是<div class="post-address">
的值“16493 KISTA”。
<div class="post-address">
还有其他有孩子的记录,我不希望这些记录被退回。我只是在寻找没有孩子而且只包含裸体文字的<div class="post-address">
。
到目前为止我的解决方案是:
var postAddressdiv = doc.DocumentNode.SelectNodes("//div[@class='address']");
if (postAddressdiv != null)
{
foreach (HtmlAgilityPack.HtmlNode node in postAddressdiv)
{
HtmlNode postAddress;
var h3 = node.Descendants("h3");
if (h3 != null)
{
if (h3.First().LastChild.InnerHtml == "Postadress")
{
MessageBox.Show("right place you are.");
postAddress = node.SelectSingleNode("//div[@class='post-address']");
var postAddressChildren = postAddress.Descendants();
if (postAddressChildren == null)
MessageBox.Show("found one!!!!");
}
}
}
}
但它不起作用。我究竟做错了什么?感谢。
答案 0 :(得分:1)
var nodes = doc.DocumentNode
.SelectNodes("//div[@class='address' and h3='Postadress']/div[@class='post-address']");