0

我有一个源 xml:

<Source>
    <First>
        <Name>Name1</Name>
    </First>
    <First>
        <Name>Name2</Name>
    </First>
</Source>

我有一个空的目标 xml,我想从源 xml 复制数据。

空目标 xml 是:

<Target>
    <Second>
        <FirstName></FirstName>
    </Second>
    <Second>
        <FirstName></FirstName>
    </Second>
</Target>

复制目标 xml 后将如下所示:

<Target>
    <Second>
        <FirstName>Name1</FirstName>
    </Second>
    <Second>
        <FirstName>Name2</FirstName>
    </Second>
</Target>

我正在寻找一个简单的 linq to xml 解决方案。问题是,我不知道如何根据源 xml 中的重复元素更新目标 xml 中的重复元素。

谢谢。

4

2 回答 2

0

您可以使用以下代码执行此操作:

var source = "<Source><First><Name>Name1</Name></First><First><Name>Name2</Name></First></Source>";
var sourceDocument = XDocument.Load(new StringReader(source));

var target = "<Target><Second><FirstName></FirstName></Second><Second><FirstName></FirstName></Second></Target>";
var targetDocument = XDocument.Load(new StringReader(target));

var sourceNameElements = sourceDocument.Descendants("First").Select(first => first.Element("Name")).ToList();
var targetNamesElements = targetDocument.Descendants("Second").Select(second => second.Element("FirstName")).ToList();

for (var i = 0; i < sourceNameElements.Count; ++i)
{
    targetNamesElements[i].SetValue(sourceNameElements[i].Value);
}

Console.WriteLine(targetDocument.ToString());
于 2013-07-17T07:53:53.530 回答
0

我不知道解决这个问题的最简单方法,这是我能想到的最好方法,并且您必须确保 Name.count 大于 FirstName.count:

        var sourceXml =XElement.Parse(source);
        var targetXml = XElement.Parse(target);
        var i = 0;
        var nameArray = (from name in sourceXml.Descendants("Name")
            select  name.Value).ToArray();
        foreach (var fName in targetXml.Descendants("FirstName"))
        {
            fName.Value = nameArray[i++];
        }
于 2013-07-17T09:43:32.170 回答