1

我正在解析一个 XML 文件,以将其与另一个 XML 文件进行比较。XML Diff 工作得很好,但我们发现一个文件中存在很多垃圾标签,而不是另一个文件,它们与我们的结果无关,但会使报告变得混乱。我已将 XML 文件加载到内存中以对其执行一些其他操作,并且我想知道是否有一种简单的方法可以同时浏览该文件,并删除所有以开头的标签,例如 color= . 颜色的值在地图上到处都是,所以不容易抓住它们都将它们删除。

在 XML Diff 中似乎没有任何方式可以指定“忽略这些标签”。

我可以翻阅文件,找到每个实例,找到它的结尾,将其删除,但我希望会有更简单的东西。如果没有,哦,好吧。

编辑:这是一段 XML:

<numericValue color="-103" hidden="no" image="stuff.jpg" key="More stuff." needsQuestionFormatting="false" system="yes" systemEquivKey="Stuff." systemImage="yes">
    <numDef increment="1" maximum="180" minimum="30">
        <unit deprecated="no" key="BPM" system="yes" />
   </numDef>
</numericValue>
4

1 回答 1

3

如果您使用的是 Linq to XML,则可以将 XML 加载到XDocumentvia:

        var doc = XDocument.Parse(xml); // Load the XML from a string

或者

        var doc = XDocument.Load(fileName); // Load the XML from a file.

然后搜索具有匹配名称的所有元素并使用System.Xml.Linq.Extensions.Remove()一次将它们全部删除:

        string prefix = "L"; // Or whatever.

        // Use doc.Root.Descendants() instead of doc.Descendants() to avoid accidentally removing the root element.
        var elements = doc.Root.Descendants().Where(e => e.Name.LocalName.StartsWith(prefix, StringComparison.Ordinal));
        elements.Remove();

更新

在您的 XML 中,color="-103"子字符串是元素的属性,而不是元素本身。要删除所有此类属性,请使用以下方法:

    public static void RemovedNamedAttributes(XElement root, string attributeLocalNamePrefix)
    {
        if (root == null)
            throw new ArgumentNullException();
        foreach (var node in root.DescendantsAndSelf())
            node.Attributes().Where(a => a.Name.LocalName == attributeLocalNamePrefix).Remove();
    }

然后这样称呼它:

        var doc = XDocument.Parse(xml); // Load the XML

        RemovedNamedAttributes(doc.Root, "color");
于 2015-06-10T23:10:24.293 回答