从 XML 文件中删除列在 XmlNodeList 中的节点

remove nodes listed into XmlNodeList from XML file

我的 XML 文件有问题。

 <?xml version="1.0" encoding="UTF-8"?>
   <config>
    <settings>
     <excelFilePath>C:\Temp\</excelFilePath>
     <mailHost>smtp</mailHost>
     <mailPort>25</mailPort>
     <mailFrom>me@test.com</mailFrom>
     <keepInCopy>
         <mailCC>email1@test.com</mailCC>
         <mailCC>email2@test.com</mailCC>
         <mailCC>email3@test.com</mailCC>
    </keepInCopy>
    <mailSubject>My Mail subject</mailSubject>
    <mailBodyPath>Templates\Template1.htm</mailBodyPath>
    </settings>
 </config>

实际上我只需要删除所有标签 "mailCC"。 我目前正在尝试此 C# 代码,但没有任何反应:

XmlDocument xml = new XmlDocument();
xml.Load(FilePath);

XmlNodeList xnList = xml.GetElementsByTagName("mailCC");
foreach (XmlNode xn in xnList)
{
    xn.RemoveChild(xn.FirstChild);
    xml.Save(FilePath);
}

你能帮帮我吗?

使用XmlDocument 将节点从其父节点中删除。但你也可以这样做:

var xn = xml.SelectSingleNode("/config/settings/keepInCopy");
if (xn != null)
{
    xn.RemoveAll(); // Remove all "mailCC" elements, but keep "keepInCopy" node **OR**
    xn.ParentNode.RemoveChild(xn); // Remove "keepInCopy" element and all children
}

删除节点将更新集合,因此您不应使用 foreach 循环。

XmlNodeList xnList = xml.GetElementsByTagName("mailCC");

while (xnList.Count > 0) {
    xnList[0].ParentNode.RemoveChild(xnList[0]);
}