使用HtmlAgilityPack刪除HtmlNode中的HtmlNode

c# html html-agility-pack nodes removechild

如何從房屋中刪除號碼節點及其值?

文件

<number>123456</number>
<house> <number> </number>Red</house>
<house> <number>12</number>Blue</house>
<number>345345</number>
etc...

碼:

private void getHouse(string houseHtml)
{
    HtmlAgilityPack.HtmlDocument htmlDoc = new HtmlAgilityPack.HtmlDocument();

    htmlDoc.Load(new System.IO.StringReader(houseHtml));

    foreach (HtmlAgilityPack.HtmlNode house in htmlDoc.DocumentNode.SelectNodes("//house"))
    {
        MessageBox.Show(house.InnerText);
    }
}

結果:

 Red
12Blue

要求的結果

Red
Blue

我一直在嘗試使用:

house.RemoveChild(house.SelectSingleNode("//number"));

和其他一些組合併運行到“未在集合中找到節點”或什麼也不會發生。它還將選擇最頂部的數字,而不是房屋標籤內的數字。

一般承認的答案

為什麼不直接刪除節點?

var numbers = htmlDoc.DocumentNode.SelectNodes("//house/number");
if (numbers != null) {
    foreach(var node in number) 
        node.Remove();
}

無論如何,XPath選擇所有節點的原因是因為您需要提供相對於當前節點的路徑:

house.SelectSingleNode("//number"); // wrong
house.SelectSingleNode(".//number"); // right


Related

許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因
許可下: CC-BY-SA with attribution
不隸屬於 Stack Overflow
這個KB合法嗎? 是的,了解原因