我有一个XML输入文件:
<?xml version="1.0" encoding="UTF-8"?>
<m2:M006 xmlns:m2="http://www.mym2.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.mym2.com http://www.mym2.com/schemas/M2RequestSchema.xsd"><M001><tkn /><m2xmlReleaseNo>020</m2xmlReleaseNo><mvmtHdr mvmtTp="CRT">
<cmt>Reduction of nominal</cmt>
</mvmtHdr><mvmtSrc>
<ctlr>SAR</ctlr>
<ctlrMvmtRef>464082138</ctlrMvmtRef>
<srcRecType>Cash Transaction</srcRecType>
<srcTransType>Reduction of Nominal</srcTransType>
</mvmtSrc><extSys>
<extSysID>SAR</extSysID>
<extSysRef>464082138</extSysRef>
</extSys><hldCpt1 amtScheme="m2">
<hldId>
<ctlrOwnr>6.00595-6</ctlrOwnr>
<ctlrAcct>6005956.6000</ctlrAcct>
<ownrRefCcy>CHF</ownrRefCcy>
<ccy>CHF</ccy>
<asst>CH0013841017</asst>
<asstIDs>
<asstRef refType="ISIN">CH0013841017</asstRef>
<asstRef refType="Valor">1384101</asstRef>
<asstRef refType="SARA">000000426547</asstRef>
</asstIDs>
<asstDetail>
<isin>CH0013841017</isin>
<type>Shares</type>
<cntry>CH/Switzerland</cntry>
<desc>Lonza Group AG Nam.</desc>
<issueCcy>CHF</issueCcy>
<latestPrc ccy="CHF">126.50</latestPrc>
<latestPrcDate>2015-04-14</latestPrcDate>
</asstDetail>
</hldId>
<effDt>2015-04-14</effDt>
<settleDt>2015-04-14</settleDt>
<qty>5000</qty>
<prc ccy="CHF">2.5</prc>
<grTrdAmt ccy="CHF">-12500</grTrdAmt>
<grAmt ccy="CHF">-12500</grAmt>
<netAmt ccy="CHF">-12500</netAmt>
</hldCpt1><hldCpt2 amtScheme="m2">
<hldId>
<ctlrOwnr>6.00595-6</ctlrOwnr>
<ctlrAcct>6005956.4000/CHF/KK</ctlrAcct>
<ccy>CHF</ccy>
<asst>CHF</asst>
<asstIDs>
<asstRef refType="CURRENCY">CHF</asstRef>
</asstIDs>
</hldId>
<effDt>2015-04-14</effDt>
<grAmt ccy="CHF">12500</grAmt>
<netAmt ccy="CHF">12500</netAmt>
</hldCpt2></M001><M001><tkn /><m2xmlReleaseNo>020</m2xmlReleaseNo><mvmtHdr mvmtTp="CCL">
<cmt>Variation Margin</cmt>
</mvmtHdr><mvmtSrc>
<ctlr>SAR</ctlr>
<ctlrMvmtRef>464068243</ctlrMvmtRef>
<srcRecType>Cash Transaction</srcRecType>
<srcTransType>Variation Margin</srcTransType>
</mvmtSrc><extSys>
<extSysID>SAR</extSysID>
<extSysRef>464068243</extSysRef>
</extSys><hldCpt1 amtScheme="m2">
<hldId>
<ctlrOwnr>6.00767-3</ctlrOwnr>
<ctlrAcct>6007673.6000</ctlrAcct>
<ownrRefCcy>EUR</ownrRefCcy>
<ccy>EUR</ccy>
<asst>73896793</asst>
<asstIDs>
<asstRef refType="Valor">73896793</asstRef>
<asstRef refType="SARA">000125009930</asstRef>
</asstIDs>
<asstDetail>
<type>Future</type>
<cntry>DE/Germany</cntry>
<desc>FGBL - BUND FUTURES Jun15 EUX</desc>
<issueCcy>EUR</issueCcy>
<latestPrc ccy="EUR">159.54</latestPrc>
<latestPrcDate>2015-04-14</latestPrcDate>
<asstDerivDetails>
<contractSize>100000</contractSize>
<expDate>2015-06-08</expDate>
<underlyingAsstIDs>
<asstRef refType="Valor">0000004209</asstRef>
</underlyingAsstIDs>
</asstDerivDetails>
</asstDetail>
</hldId>
<effDt>2015-04-14</effDt>
<settleDt>2015-04-14</settleDt>
<qty>-10</qty>
<prc ccy="EUR">989898</prc>
<grTrdAmt ccy="EUR">100</grTrdAmt>
<grAmt ccy="EUR">100</grAmt>
<netAmt ccy="EUR">100</netAmt>
</hldCpt1><hldCpt2 amtScheme="m2">
<hldId>
<ctlrOwnr>6.00767-3</ctlrOwnr>
<ctlrAcct>6007673.4004/EUR/KK 'Variation Margin'</ctlrAcct>
<ccy>EUR</ccy>
<asst>EUR</asst>
<asstIDs>
<asstRef refType="CURRENCY">EUR</asstRef>
</asstIDs>
</hldId>
<effDt>2015-04-14</effDt>
<grAmt ccy="EUR">-100</grAmt>
<netAmt ccy="EUR">-100</netAmt>
</hldCpt2></M001><M001><tkn /><m2xmlReleaseNo>020</m2xmlReleaseNo><mvmtHdr mvmtTp="AOU">
<cmt>Variation Margin</cmt>
</mvmtHdr><mvmtSrc>
<ctlr>SAR</ctlr>
<ctlrMvmtRef>464068485</ctlrMvmtRef>
<srcRecType>Cash Transaction</srcRecType>
<srcTransType>Variation Margin</srcTransType>
</mvmtSrc><extSys>
<extSysID>SAR</extSysID>
<extSysRef>464068485</extSysRef>
</extSys><hldCpt1 amtScheme="m2">
<hldId>
<ctlrOwnr>6.01279-4</ctlrOwnr>
<ctlrAcct>6012794.6000</ctlrAcct>
<ownrRefCcy>EUR</ownrRefCcy>
<ccy>CHF</ccy>
<asst>74040383</asst>
<asstIDs>
<asstRef refType="Valor">74040383</asstRef>
<asstRef refType="SARA">000125132191</asstRef>
</asstIDs>
<asstDetail>
<type>Future</type>
<cntry>CH/Switzerland</cntry>
<desc>FSMI FUTURES Jun15 EUX</desc>
<issueCcy>CHF</issueCcy>
<latestPrc ccy="CHF">9288.00</latestPrc>
<latestPrcDate>2015-04-14</latestPrcDate>
<asstDerivDetails>
<contractSize>10</contractSize>
<expDate>2015-06-19</expDate>
<underlyingAsstIDs>
<asstRef refType="Valor">0000004208</asstRef>
</underlyingAsstIDs>
</asstDerivDetails>
</asstDetail>
</hldId>
<effDt>2015-04-14</effDt>
<settleDt>2015-04-14</settleDt>
<qty>-14</qty>
<prc ccy="CHF">989898</prc>
<grTrdAmt ccy="CHF">-6440</grTrdAmt>
<grAmt ccy="CHF">-6440</grAmt>
<netAmt ccy="CHF">-6440</netAmt>
</hldCpt1><hldCpt2 amtScheme="m2">
<hldId>
<ctlrOwnr>6.01279-4</ctlrOwnr>
<ctlrAcct>6012794.4019/CHF/KK 'Variation Margin'</ctlrAcct>
<ccy>CHF</ccy>
<asst>CHF</asst>
<asstIDs>
<asstRef refType="CURRENCY">CHF</asstRef>
</asstIDs>
</hldId>
<effDt>2015-04-14</effDt>
<grAmt ccy="CHF">6440</grAmt>
<netAmt ccy="CHF">6440</netAmt>
</hldCpt2></M001></m2:M006>
在处理文件之前,我必须重新排序M001记录。订单应该是:
<ctlrMvmtRef>XXXXXXXXX</ctlrMvmtRef>
mvmtTp="XXX"
数据本身应保持不变。只需要重新订购M001记录。
我试过这个xslt:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="@*|node()">
<xsl:copy><xsl:apply-templates select="@* | node()"/></xsl:copy>
</xsl:template>
<xsl:template match="M006">
<xsl:copy>
<xsl:apply-templates select="@*|node()">
<xsl:sort select="mvmtTp" order="descending"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
但这不起作用
这个有效
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="node()[not(self::comment())][not(self::*)]|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="*">
<xsl:copy>
<xsl:apply-templates select="@*">
<xsl:sort select="name()"/>
</xsl:apply-templates>
<xsl:apply-templates>
<xsl:sort select="mvmtSrc/ctlrMvmtRef"/>
<xsl:sort select="mvmtHdr/@mvmtTp"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
如果我不想按照严格的字母顺序对mvmtTp进行排序,还有一点,例如 代替 AIN AOU DEP 像这样 AOU AIN DEP
这意味着AOU总是在AIN之前
答案 0 :(得分:-1)
试试这个
const string FILENAME = @"c:\temp\test.xml";
static void Main(string[] args)
{
XDocument input = XDocument.Load(FILENAME);
var x = input.Root.Elements("M001").AsEnumerable()
.OrderBy(y => y.Element("mvmtSrc").Element("ctlrMvmtRef").Value).ToList();
XDocument doc2 = new XDocument(new XElement("M006", x));
}