如何查找XML的节点并将其删除
本文关键字:节点 删除 XML 何查找 查找 | 更新日期: 2023-09-27 17:50:50
我有一个像这样的xml
<Order>
<OrderSections>
<OrderSection type="1" name="S 1" id="3">
<ShippingAmount>15.02</ShippingAmount>
</OrderSection>
<OrderSection type="1" name="S 2" id="4">
<ShippingAmount>0</ShippingAmount>
</OrderSection>
</OrderSections>
</Order>
如何找到id=4的order部分并将其从XmlDocument中删除?我正在查看这个示例,但这是不同的,因为正在搜索的值属于像
这样的节点<players>
<player>
<name>User2</name>
</player>
</players>
但是我的XML有<OrderSection>
属性值内的id
您需要为属性使用@
:
XmlNode node = doc.SelectSingleNode("/Order/OrderSections/OrderSection[@id='4']");
node.ParentNode.RemoveChild(node);
看一下XPath语法
使用XmlDocument类和xpath查找元素
string path = "orders.xml";
XmlDocument XMLDoc = new XmlDocument();
XMLDoc.Load(path);
foreach (XmlNode entry in XMLDoc.SelectNodes("//OrderSection[@id='4']"))
{
entry.ParentNode.RemoveChild(entry);
}
您可以使用Linq to Xml:
var xdoc = XDocument.Load(path_to_xml);
xdoc.Descendants("OrderSection")
.Where(os => (int)os.Attribute("id") == 3)
.Remove();
xdoc.Save(path_to_xml);