基于现有XML文件创建XDocument

时间:2015-04-26 15:48:19

标签: c# winforms linq-to-xml

我尝试基于现有的XML文件创建XDocument并将其与TreeView一起使用。我想通过Group元素对联系人进行分组。

XML文件结构 -

<Contacts>
  <Contact>
    <First_Name>Ren</First_Name>
    <Last_Name>Fuji</Last_Name>
    <Group>Test</Group>
    <Home_Number>Unavailable</Home_Number>
    <Mobile_Number>Unavailable</Mobile_Number>
    <Image></Image>
  </Contact>
<Contacts>

以下是创建XDocument对象的方法 -

     static XDocument groupXDoc = new XDocument();
     private static void CreateGroupsXML()
            {
                XElement root = new XElement("Groups");
                groupXDoc.Add(root);
                foreach (XElement xelement in xdoc.Element("Contacts").Elements("Contact").ToList())
                {
                    String groupData = (String)xelement.Element("Group").Value;
                    XElement groups = new XElement("Group", new XAttribute("Name", groupData));
                    root.Add(groups);
                    if (groupXDoc.Root.Element("Group").FirstAttribute.Value == xelement.Element("Group").Value)
                    {
                        groups.Add(new XElement("First_Name", (String)xelement.Element("First_Name").Value),
                            new XElement("Last_Name", (String)xelement.Element("Last_Name").Value),
                            new XElement("Home_Number", (String)xelement.Element("Home_Number").Value),
                            new XElement("Mobile_Number", (String)xelement.Element("Mobile_Number").Value)
                            );
                    }
                }
            }

然而,这是我得到的结果 -

enter image description here

正如您所看到的,只有第一个联系人正确显示,但其他两个联系人没有显示。有人可以帮帮我吗?

1 个答案:

答案 0 :(得分:1)

private static XDocument GroupContactsByGroupField(XDocument doc)
    {
        var contacts = doc.Descendants("Contact").Select(x => new
        {
            FirstName = x.Element("First_Name").Value,
            LastName = x.Element("Last_Name").Value,
            Group = x.Element("Group").Value,
            HomeNumber = x.Element("Home_Number").Value,
            MobileNumber = x.Element("Mobile_Number").Value
        });
        var contactsGroupedByGroup = contacts.GroupBy(x => x.Group);

        var newDoc = new XDocument(new XElement("Groups", contactsGroupedByGroup.Select(x =>
           new XElement("Group", new XAttribute("Name", x.Key),
            x.Select(y => new XElement("Contact",
                new XElement("First_Name", y.FirstName),
                new XElement("Last_Name", y.LastName),
                new XElement("Home_Number", y.HomeNumber),
                new XElement("Mobile_Number", y.MobileNumber)
            ))))));
        return newDoc;
    }