0

我有一个这样的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 的订单部分并将其从 XmlDocument 中删除?,我正在查看这个示例,但这是不同的,因为正在搜索的值属于类似的节点

<players>
<player> 
    <name>User2</name>
 </player>
</players>

但我的 XML 在<OrderSection>属性值中有 id。

4

3 回答 3

3

您需要@用于属性:

XmlNode node = doc.SelectSingleNode("/Order/OrderSections/OrderSection[@id='4']");
node.ParentNode.RemoveChild(node);

查看XPath 语法

于 2013-01-05T21:31:03.647 回答
2

使用 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);
}
于 2013-01-05T21:31:39.423 回答
0

您可以使用 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);
于 2013-01-05T21:26:01.917 回答