使用Linq to XML选择多个元素

本文关键字:元素 选择 XML Linq to 使用 | 更新日期: 2023-09-27 18:13:12

我有一个c#应用程序,需要从Linq to XML集合中提取多个元素。

我从XML文件

中提取了以下内容
    <SNS>
    <uniqueSystem><system>49</system><label>Engines</label>
        <uniqueSubsystem><subsystem>30</subsystem><label>APU</label>
            <uniqueUnit><unit>00</unit><label>Starter</label>
    </uniqueUnit>
    </uniqueSubsystem>
    </uniqueSystem>
    <uniqueSystem><system>50</system><label>Hydraulics</label>
        <uniqueSubsystem><subsystem>30</subsystem><label>Reservoir</label>
            <uniqueUnit><unit>00</unit><label>Pump</label>
    </uniqueUnit>
    </uniqueSubsystem>
</uniqueSystem></SNS>

我需要从每个' uniquessystem '元素中提取值。所以在上面的例子中,在"SNS"元素下有2个"uniquessystem"元素,在每个元素中都有"uniques子系统"元素和"uniqueUnit"元素,每个元素都有"label"元素。我需要提取这些数据来构建一个TreeView。

我的问题是使用Linq提取多个元素。我该怎么做呢?

现在我有

var item = from items in doc.Descendants("SNS").Descendants("uniqueSystem").Descendants("system")
                          orderby items.Value
                          select items.Descendants("uniqueSystem");

我认为这将给我一个' uniquessystem '元素的集合,我现在需要从中提取多个元素的值。有人能帮忙吗?

我的下一个尝试如下,但这给了我一个空引用异常:

var item = from items in doc.Descendants("SNS").Descendants("uniqueSystem").Descendants("system")
                          orderby items.Value
                          select items.Descendants("uniqueSystem");
                foreach (var e in item)
                {
                    string sys = e.Descendants("system").FirstOrDefault().Value;
                    string sysLabel = e.Descendants("system").Descendants("label").FirstOrDefault().Value;
                    string subsys = e.Descendants("subsystem").FirstOrDefault().Value;
                    string subsysLabel = e.Descendants("subsystem").Descendants("label").FirstOrDefault().Value;
                    string unit = e.Descendants("unit").FirstOrDefault().Value;
                    string unitLabel = e.Descendants("unit").Descendants("label").FirstOrDefault().Value;
                    buildSystemNodes(sys, sysLabel);
                    //getSubSystems(myitem);
                }

使用Linq to XML选择多个元素

因此,我在下面编写的代码将生成树视图。我使用的树视图类位于命名空间System.Web.UI.WebControls中。函数是O(n^3)。

    public void ProcessXml(string document)
    {
        var doc = XDocument.Parse(document, LoadOptions.None);
        var uniqueSystemList = doc.Element("SNS").Elements();
        var treeView = new TreeView();
        string value = string.Empty;
        string text = string.Empty;
        foreach (var uniqueSystem in uniqueSystemList)
        {
            value = uniqueSystem.Element("label").Value.ToString();
            text = uniqueSystem.Element("system").Value.ToString();
            var uniqueSystemNode = new TreeNode(text, value);
            var uniqueSubsystemList = uniqueSystem.Elements("uniqueSubsystem");
            foreach (var uniqueSubSystem in uniqueSubsystemList)
            {
                value = uniqueSubSystem.Element("label").Value.ToString();
                text = uniqueSubSystem.Element("subsystem").Value.ToString();
                var uniqueSubSystemNode = new TreeNode(text, value);
                var uniqueUnitList = uniqueSubSystem.Elements("uniqueUnit");
                foreach (var uniqueUnit in uniqueUnitList)
                {
                    value = uniqueUnit.Element("label").Value.ToString();
                    text = uniqueUnit.Element("unit").Value.ToString();
                    var uniqueUnitNode = new TreeNode(text, value);
                    uniqueSubSystemNode.ChildNodes.Add(uniqueUnitNode);
                }
                uniqueSystemNode.ChildNodes.Add(uniqueSubSystemNode);
            }
            treeView.Nodes.Add(uniqueSystemNode);
        }
    }

检查这种代码是否符合您的要求

        var doc = XDocument.Load(@"..'XMLFile1.xml");
        var res = doc.XPathSelectElements("/SNS/uniqueSystem");
        foreach (var item in res)
        {
            var us = new UniqueSystem
            {
                System = int.Parse(item.Element("system").Value),
                Label = item.Element("label").Value
            };
            if (item.Element("uniqueSubsystem") != null)
            {
                 // process the logic here
            }
        }

可以使用如下所示的模型绑定到

class UniqueSystem
{
    public int System { get; set; }
    public string Label { get; set; }
    public List<uniqueSubsystem> SubSystems { get; set; }
}
class uniqueSubsystem
{
    public int subsystem { get; set; }
    public string Label { get; set; }
    public List<uniqueUnit> Units { get; set; }
}
class uniqueUnit
{
    public int unit { get; set; }
    public string label { get; set; }
}

通过下面的代码,您可以获得 uniqueSubsystem

    XmlNodeList nodes = xml.SelectNodes("SNS/uniqueSystem/uniqueSubsystem");
    foreach (XmlNode i in nodes)
    {
        Response.Write(i.InnerXml);
    }

如果你想要节点:

        XmlNodeList labels1 = xml.SelectNodes("SNS/uniqueSystem/uniqueSubsystem/label");
        XmlNodeList labels2 = xml.SelectNodes("SNS/uniqueSystem/uniqueSubsystem/uniqueUnit/label");
        Response.Write("SNS/uniqueSystem/uniqueSubsystem/label<br />");
        foreach (XmlNode i in labels1)
        {
            Response.Write(i.InnerText+"<br />");
        }
        Response.Write("<br />SNS/uniqueSystem/uniqueSubsystem/uniqueUnit/label<br />");
        foreach (XmlNode i in labels2)
        {
            Response.Write(i.InnerText+"<br />");
        }