从Xml Advertisement文件中删除整个Node

本文关键字:Node 删除 Xml Advertisement 文件 | 更新日期: 2023-09-27 17:49:18

我试图删除匹配特定条件的整个XmlNode

我的xml文件的格式如下:

    <?xml version="1.0" encoding="utf-8"?>
<Advertisements>
  <Ad>
    <ImageUrl>image/Hydrangeas.jpg</ImageUrl>
    <NavigateUrl>www.google.com</NavigateUrl>
    <AlternateText>nbfndbf</AlternateText>
    <ID>0</ID>
    <Impressions>1</Impressions>
  </Ad>
</Advertisements>

我的删除代码:

      XElement x = 
                new XElement("Ad",
                  new XElement("ImageUrl", lblImageURL.Text),
                  new XElement("NavigateUrl", lblImageURL.Text),
                  new XElement("AlternateText", lblAlternateText.Text),
                    new XElement("ID", lblID.Text),
             new XElement("Impressions", lblfrequency.Text));

            string filepath = Request.PhysicalApplicationPath.ToString() + "Adrotator.xml";

            XmlDocument xD = new XmlDocument();
            xD.LoadXml(x.ToString());
            XmlNode xN = xD.FirstChild;
            xN.ParentNode.RemoveChild(xN);

            **xD.Save(filepath);**

我得到一个错误无效的XML文档。文档没有根元素

从Xml Advertisement文件中删除整个Node

您可以使用linq to xml来实现这个示例,如何删除值ID = 0的节点

var q = (from c in doc.Descendants("Advertisements")
        from v in c.Elements("Ad")
        where (int) v.Element("ID") == 0
       select v).Remove();
下面是另一个使用xpath 的例子
doc.XPathSelectElement("Advertisements/Ad[ID = 0]").Remove();

用下面的代码创建一个新的XDocument (doc):

XDocument doc = XDocument.Load(filepath);

有什么在Xml文件(与根元素)?此外,您似乎没有在代码中使用doc,因此至少不是必需的。