微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

XSLT 对子元素排序

如何解决XSLT 对子元素排序

我试图输出整个 XML,但 EVENT 元素按 ID 排序。作为 XSLT 的新手,我以为我仍然会尝试一下,但经过多次尝试并阅读其他示例以及如何指南后,我仍然无法获得我认为很简单的工作。

<?xml version="1.0" encoding="UTF-8"?>
<PublishWCWORKORDEROUT xmlns="http://www.xcessteel.com/maxo" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" creationDateTime="2021-05-10T08:23:18+00:00" transLanguage="EN" baseLanguage="EN" messageID="3116171.1620634998889850919" maxoVersion="7 6 20190514-1348 V7611-365" event="1">
  <WCWORKORDEROUTSet>
    <WORKORDER action="Replace">
      <ACTCATEGORY />
      <X_3857>1.1838832494481975E7</X_3857>
      <Y_3857>-2766476.1752903816</Y_3857>
      <SPEC>
        <ALNVALUE />
        <REFID xsi:nil="true" />
        <ASSETATTRID>ACCOUNT_NO</ASSETATTRID>
        <CHANGEBY>ADMIN</CHANGEBY>
      </SPEC>
      <SPEC>
        <ALNVALUE />
        <REFID xsi:nil="true" />
      </SPEC>
      <SPEC>
        <ALNVALUE />
        <REFID xsi:nil="true" />
        <ASSETATTRID>METER_LOCATION</ASSETATTRID>
      </SPEC>
      <EVENT>
        <ID>CCC333</ID>
        <WORKTYPE>UNPLANNED</WORKTYPE>
      </EVENT>
      <EVENT>
        <ID>AAA111</ID>
        <WORKTYPE>PLANNED</WORKTYPE>
      </EVENT>
      <EVENT>
        <ID>BBB222</ID>
        <WORKTYPE>SCHEDULED</WORKTYPE>
      </EVENT>
      <ASSIGNMENT>
        <AMCREW />
        <WPLABORID>209336</WPLABORID>
      </ASSIGNMENT>
      <WCWODETAILS>
        <REFID xsi:nil="true" />
        <CUSTOMERNAME />
        <WCREGION>SWR</WCREGION>
        <ID>96057400</ID>
      </WCWODETAILS>
    </WORKORDER>
  </WCWORKORDEROUTSet>
</PublishWCWORKORDEROUT>

我已经尝试过这个 XSLT,但显然它不正确。

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<!-- identity transform -->
<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="/PublishWCWORKORDEROUT">
    <xsl:copy>
        <xsl:apply-templates select="EVENT">
            <xsl:sort select="ID"/>
        </xsl:apply-templates>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>

解决方法

您必须声明命名空间 xmlns="http://www.xcessteel.com/maxo",然后在您的匹配项中使用该前缀,排序可以这样完成:

在 2021-05-24 10:19 编辑:缺少属性 action="Replace"

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" 
  xmlns:maxo="http://www.xcessteel.com/maxo"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
  
  <!-- identity transform -->
  <xsl:template match="@*|node()">
    <xsl:copy>
      <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
  </xsl:template>
  
  <xsl:template match="maxo:WORKORDER">
    <xsl:copy>
      <!-- Following line was missing -->
      <xsl:apply-templates select="@*"/>
      <xsl:apply-templates select="maxo:EVENT[1]/preceding-sibling::*"/>
      <xsl:apply-templates select="maxo:EVENT">
        <xsl:sort select="maxo:ID"/>
      </xsl:apply-templates>
      <xsl:apply-templates select="maxo:EVENT[ position()=last()]/following-sibling::*"/>
    </xsl:copy>
  </xsl:template>
  
</xsl:stylesheet>

作为替代方案,以下方法也适用:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" 
  xmlns:maxo="http://www.xcessteel.com/maxo"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
  
  <!-- identity transform -->
  <xsl:template match="@*|node()">
    <xsl:copy>
      <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
  </xsl:template>
  
  <xsl:template match="maxo:EVENT[not(preceding-sibling:: maxo:EVENT)]">
    <xsl:for-each select=".|following-sibling:: maxo:EVENT">
      <xsl:sort select="maxo:ID"/>
      <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
      </xsl:copy>
    </xsl:for-each>
    
  </xsl:template>
    
  <xsl:template match="maxo:EVENT[ preceding-sibling:: maxo:EVENT]"/>  
  
</xsl:stylesheet>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。