使用linq to xml将多个xml文件合并为一个

时间:2013-09-10 10:43:57

标签: c# xml linq

说,这是我的XML文件

XML文件1

<Root>
    <Parent>
        <Child>1</Child>
        <child>2</Child>
    </Parent>
    <Parent>
         <child>3</Child>
         <Child>4</Child>
    </Parent>
 </Root>

Xml文件2

<Root>
    <Parent>
       <Child>5</Child>
       <Child>6</Child>
    </Parent>
    <Parent>
        <Child>7</Child>
        <Child>8</Child>
    </Parent>
 </Root>

结果XML文件(根据我的要求)

<Root>
    <Parent>
       <Child>1</Child>
       <Child>2</Child>
    </Parent>
    <Parent>
        <Child>3</Child>
        <Child>4</Child>
    </Parent>
    <Parent>
       <Child>5</Child>
       <Child>6</Child>
    </Parent>
    <Parent>
        <Child>7</Child>
        <Child>8</Child>
    </Parent>

 </Root>

在下面的函数中,我提供了要在字符串数组中组合并尝试合并它们的xml文件的路径

private void BindDataInGrid(string[] argFilePaths)
{
    XDocument tempFile = XDocument.Load(argFilePaths[0]);

    for (int i = 1; i < argFilePaths.Length; i++)
    {
        tempFile.Descendants("Parent")
           .Union(XDocument.Load(argFilePaths[i]).Root.Descendants("Parent"));
    }
 }

在tempFile中,只有第一个文件而不是其他文件才有记录。

1 个答案:

答案 0 :(得分:0)

首先,我很抱歉,因为我忘了提到我不想永久保存结果文件。我相应地解决了它。

private void BindDataInGrid(string[] argFilePaths)
{
    List<Parent> recordsList = new List<Parent>();

        for (int i = 0; i < argFilePaths.Length; i++)
        {
           recordsList.AddRange
               (
                     XDocument.Load(argFilePaths[i]).Root.Descendants("Resident")
                     .Select(data => new Parent()
                     {
                         Child1 = data.Element("Child1").Value,
                         Child2 = data.Element("Child2").Value,
                     }).ToList()
                );
        }
}

使用recordsList作为数据源。