有一个 XML 文件:
<favorites>
<movies>
<movie title="The Godfather" year="1974" />
<movie title="The Terminator" year="1984" />
<movie title="Dark Knight" year="2008" />
</movies>
<books>
<book title = "1984" author="George Orwell" />
<book title = "Robinson Crusoe"" author="Daniel Defoe"/>
<book title = "Frankenstein" author="Mary Shelly" />
</books>
<music>
<artist title = "Beatles" genre="rock" />
<artist title = "Queen" genre="rock" />
<artist title = "Metallica" rock="heavy metal" />
</music>
</favorites>
我需要使用所有父节点和子节点过滤特定节点(音乐)。 结果应该是:
<favorites>
<music>
<artist title="Beatles" genre="rock" />
<artist title="Queen" genre="rock" />
<artist title="Metallica" rock="heavy metal" />
</music>
</favorites>
我找到了使用 System.XML 和 LINQ 过滤 XML 的解决方案:
XDocument xdoc = XDocument.Parse(xmlString);
xdoc.Descendants()
.Where(x => x.Name != "favorites" & x.Name != "music" & x.Name != "artist")
.Remove();
Console.WriteLine(xdoc.ToString());
工作样本在这里:https://dotnetfiddle.net/NnA4h7#
问题是我必须在查询中指定所有父节点和子节点。
有没有办法通过仅指定想要的节点(电影、书籍、音乐)来获得相同的结果?
最佳答案
这是另一种更简单的方法:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;
namespace ConsoleApplication1
{
class Program
{
const string FILENAME = @"c:\temp\test.xml";
static void Main(string[] args)
{
XDocument doc = XDocument.Load(FILENAME);
XElement favorites = doc.Descendants("favorites").FirstOrDefault();
favorites.ReplaceNodes(favorites.Element("music")));
}
}
}
关于C#:获取带有所有父标签的 XML 节点内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49867071/