用C#中的不同标记对xelement进行排序基于值

问题描述:

我有下面的XML,需要根据值sequence标记进行排序,用于排序的XML放置在总计根节点中,这是否可以在C#中使用。如果序列为空或正在重复,则将该标签留在原位。用C#中的不同标记对xelement进行排序基于值

<Totals sequence="001" label="Totals" tooltip="Totals"> 
    <ReturnTotalGrossReceipts sequence="001" datatype="Money" label="Total Receipts" /> 
    <ReturnTotalAdjusts sequence="002" datatype="Money" label="Total Adjustments" /> 
    <ReturnTotalTaxableSales sequence="003" datatype="Money" label="Total Taxable Sales" /> 
    <ReturnTotalTax sequence="005" datatype="Money" label="Total Amount of Tax" /> 
    <ReturnTimelyPay sequence="004" datatype="Money" label="Total Pay" /> 
    <ReturnTotalSalesTaxDue sequence="006" datatype="Money" label="Total Due" /> 
    <ReturnInterest sequence="006" datatype="Money" label="Interest" /> 
</Totals> 
+0

无法排序并留在原地。是的,你可以很容易地排序,你可能想要在序列号相同的两个字段上排序。 – jdweng

+0

只有一个字段可用,如果序列为空或重复可以对 – amity2

+0

进行排序,因为所有标记在根标记总计内都不相同,orderby在元素上失败 – amity2

以下代码应该为您提供一个排序列表,如果sequence元素为空,则留下元素。

var sXml = "<Totals sequence=\"001\" label=\"Totals\" tooltip=\"Totals\"><ReturnTotalGrossReceipts sequence=\"001\" datatype=\"Money\" label=\"Total Receipts\" /><ReturnTotalAdjusts sequence=\"002\" datatype=\"Money\" label=\"Total Adjustments\" /><ReturnTotalTaxableSales sequence=\"003\" datatype=\"Money\" label=\"Total Taxable Sales\" /><ReturnTotalTax sequence=\"005\" datatype=\"Money\" label=\"Total Amount of Tax\" /><ReturnTimelyPay sequence=\"004\" datatype=\"Money\" label=\"Total Pay\" /><ReturnTotalSalesTaxDue sequence=\"006\" datatype=\"Money\" label=\"Total Due\" /><ReturnInterest sequence=\"006\" datatype=\"Money\" label=\"Interest\" /></Totals>"; 
var xml = XElement.Parse(sXml); 
xml 
    .Descendants() 
    .Select((x, i) => new { Index = i, Element = x }) 
    .OrderBy(x => Convert.ToInt32(x.Element.Attribute("sequence")?.Value ?? x.Index.ToString())) 
    .Select(x => x.Element); 

试试这个

using System.Xml.Linq; 

namespace ConsoleApplication29 
{ 
    class Program 
    { 
     const string FILENAME = @"c:\temp\test.xml"; 
     static void Main(string[] args) 
     { 
      XDocument xdoc = XDocument.Load(FILENAME); 
      XElement total = xdoc.Descendants("Totals").First(); 


      total.ReplaceNodes(total.Elements().OrderBy(x => (int)x.Attribute("sequence"))); 
     } 

    } 

}