繁体   English   中英

Xml.Linq:反转 XML 的子节点

[英]Xml.Linq: Reversing child-nodes of a XML

我根据用户输入在运行时创建了以下 XML 文件。

<Parent>
    <X1>1</X1>
    <X2>
        <Y1>
            <Rank>4</Rank>
        </Y1>
        <Y1>
            <Rank>3</Rank>
        </Y1>
        <Y1>
            <Rank>2</Rank>
        </Y1>
        <Y1>
            <Rank>1</Rank>
        </Y1>
    </X2>
</Parent>

现在,我想以<Rank>升序排列的方式反转子节点。 我想要以下输出

<Parent>
    <X1>1</X1>
    <X2>
        <Y1>
            <Rank>1</Rank>
        </Y1>
        <Y1>
            <Rank>2</Rank>
        </Y1>
        <Y1>
            <Rank>3</Rank>
        </Y1>
        <Y1>
            <Rank>4</Rank>
        </Y1>       
    </X2>
</Parent>

创建此问题是因为我使用的是 AddFirst 方法。 我没有找到任何与 AddFirst 完全相反的方法。

您可以使用反向

例子:

static void Main(string[] args)
{
    XElement srcTree = new XElement("Parent",
                new XElement("X1", 1),
                new XElement("X2",
                    new XElement("Y1", new XElement("Rank", 4)),
                    new XElement("Y1", new XElement("Rank", 3)),
                    new XElement("Y1", new XElement("Rank", 2)),
                    new XElement("Y1", new XElement("Rank", 1)))
            );

    var reverseList = srcTree.Elements("X2").Descendants("Y1").InDocumentOrder().Reverse().ToList();

    srcTree.Element("X2").Remove();
    srcTree.Add(new XElement("X2", reverseList));


    Console.WriteLine(srcTree);
    Console.ReadLine();
}

它会给你想要的结果:

<Parent>
  <X1>1</X1>
  <X2>
    <Y1>
      <Rank>1</Rank>
    </Y1>
    <Y1>
      <Rank>2</Rank>
    </Y1>
    <Y1>
      <Rank>3</Rank>
    </Y1>
    <Y1>
      <Rank>4</Rank>
    </Y1>
  </X2>
</Parent>

暂无
暂无

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

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