使用Linq to XML选择多个元素

时间:2013-05-13 08:51:08

标签: c# xml linq-to-xml

我有一个C#应用程序,需要从Linq到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);
                }

3 个答案:

答案 0 :(得分:0)

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

如果这有助于你,请告诉我。

答案 1 :(得分:0)

检查此类代码是否符合您的要求

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

答案 2 :(得分:0)

所以我在下面编写的代码将生成树视图。我正在使用的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);
        }
    }