[英]Delete multiple XML nodes in C# using Linq
我正在嘗試刪除特定element(path)
包含值的多個節點,但我收到System.NullReferenceException
任何我出錯的幫助,我將不勝感激。
我的 xml 看起來像這樣:
<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<ApplicationData Version="12.5.1" RootPath="FireFox-FILES">
<RegistrySystem>
<DIR Operation="+" Path="C:\Temp\Microsoft\MediaPlayer\ShimInclusionList" />
<DIR Operation="+" Path="C:\Temp\MediaPlayer\ShimInclusionList\MM.EXE" />
<DIR Operation="+" Path="C:\Temp\MediaPlayer\ShimInclusionList\plugin-container.exe" />
<DIR Operation="+" Path="C:\Temp\Microsoft\MediaPlayer">
<ENTRY Name="" Value="43.0.4" Type="1" />
<ENTRY Name="CurrentVersion" Value="43.0.4 (x86 en-GB)" Type="1" />
</DIR>
<DIR Operation="+" Path="C:\Program Files\Microsoft\MediaPlayer\ShimInclusionList\plugin-container.exe" />
<DIR Operation="+" Path="C:\Program Files\Microsoft\MediaPlayer\ShimInclusionList2\plugin.exe" />
<DIR Operation="+" Path="C:\Program Files\Microsoft\MediaPlayer\ShimInclusionList2\container.exe" />
<DIR Operation="+" Path="C:\Program Files\Microsoft\MediaPlayer\ShimInclusionList4">
<ENTRY Name="" Value="43.0.4" Type="1" />
<ENTRY Name="CurrentVersion" Value="43.0.4 (x86 en-GB)" Type="1" />
</DIR>
</RegistrySystem>
</ApplicationData>
我的代碼如下所示:
XDocument xdoc = XDocument.Load(XmlFile);
foreach (var node in xdoc.Descendants("DIR").Where(status => status.Attribute("Path").Value.Contains(@"C:\Temp\")))
{
node.Remove();
}
xdoc.Save(XmlFile);
我不確定我哪里出錯了。
我不確定您為什么會收到異常,但我強烈懷疑這是因為您在查詢文檔時正在修改文檔。
如果您更改代碼以使用ToList()
調用來獲取要刪除的節點列表,則不會拋出:
foreach (var node in xdoc.Descendants("DIR")
.Where(status => status.Attribute("Path").Value.Contains(@"C:\Temp\"))
.ToList())
{
node.Remove();
}
然而,這並不是最好的方法。 最好的方法是使用Remove(this IEnumerable<XElement>)
擴展方法:
xdoc.Descendants("DIR")
.Where(status => status.Attribute("Path").Value.Contains(@"C:\Temp\"))
.Remove();
根本不需要foreach
循環。 現在要使其在沒有Path
屬性的DIR
元素面前健壯,您可以改為轉換為字符串:
xdoc.Descendants("DIR")
.Where(status => ((string) status.Attribute("Path") ?? "").Contains(@"C:\Temp\"))
.Remove();
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.