0

我有一个这样的xml结构:-

<Person id="1" Name="Rahul lamba" Manager_Id="13" Department="IT" />
<Person id="6" Name="Saurabh" Manager_Id="4" Department="IT" />
<Person id="5" Name="Amitesh" Manager_Id="6" Department="IT" />

现在我想从每一行的 XML中删除Manager_Id节点。

我试过了,但没有任何效果

XmlNodeList l = doc.GetElementsByTagName("Person");

 foreach (XmlNode item in l)
     {
         foreach (var  item1 in item.ChildNodes)
             {
                 if (item1 == "Manager_Id")
                     {
                        //Code to remove Manager_Id node.
                     }
             }
      }

我怎样才能做到这一点?

提前谢谢。

4

2 回答 2

3

您可以使用 Linq To Xml 轻松完成,

var xDoc = XDocument.Parse(xmlstring); //XDocument.Load(filename)

xDoc.Descendants("Person")
    .Select(x => x.Attribute("Manager_Id"))
    .Where(x => x!=null)
    .ToList().ForEach(a => a.Remove());

var newxml = xDoc.ToString(); //xDoc.Save(fileName);
于 2012-12-13T10:55:06.210 回答
0
XmlTextReader reader = new XmlTextReader(@"C:\MyXml.xml");
        reader.Read();
        XmlDocument doc = new XmlDocument();
        doc.Load(reader);
        XmlNode node = doc.SelectSingleNode("/Persons/Person[@Manager_Id=6]");
        node.ParentNode.RemoveChild(node);
        reader.Close();
        doc.Save(@"D:\MyXml.xml"); 

使用 att 删除所有节点

XmlTextReader reader = new XmlTextReader(@"C:\MyXml.xml");
        reader.Read();
        XmlDocument doc = new XmlDocument();
        doc.Load(reader);
        XmlNodeList lstNode = doc.SelectNodes("/Persons/Person[@Manager_Id]");
        foreach (XmlNode node in lstNode)
        {
            node.ParentNode.RemoveChild(node);
        }
        reader.Close();
        doc.Save(@"C:\MyXml.xml"); 
于 2012-12-13T11:01:20.230 回答