繁体   English   中英

使用Linq to XML选择多个元素

[英]Select multiple elements with Linq to XML

我有一个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>

我需要从每个“ uniqueSystem”元素中提取值。 因此,在上面的示例中,在“ SNS”元素下有2个“ uniqueSystem”元素,并且在每个元素内都有“ uniqueSubsystem”元素和“ uniqueUnit”元素,每个元素均带有“ label”元素。 我需要提取此数据以构建TreeView。

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

此刻我有

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

我认为这将为我提供“ uniqueSystem”元素的集合,现在我需要从中提取其中多个元素的值。 有人可以帮忙吗?

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

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);
                }

通过以下代码,您可以获得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 />");
        }

让我知道这是否对您有帮助。

检查这种代码是否可以满足您的要求

        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; }
}

因此,我在下面编写的代码将生成树视图。 我正在使用的treeview类位于名称空间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);
        }
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM