输入数据:下面是从源获取的输入数据。我们如何通过XSLT映射SCPI来实现,提前感谢,期待您的回复。我有以下问题(这个领域经常讨论这个问题,但我仍然无法得到确切的解决方案(:我有一个XML,如下所示:
<orderHeader>
<distributionChannelCode>10</distributionChannelCode>
<orderItem>
<productCode>AQ7481-002-001</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-004</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-001</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-002</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-004</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-002</productCode>
</orderItem>
</orderHeader>
所需输出:
<orderHeader>
<distributionChannelCode>10</distributionChannelCode>
<orderItem>
<productCode>AQ7481-002-001</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-002</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-004</productCode>
</orderItem>
</orderHeader>
<orderHeader>
<distributionChannelCode>10</distributionChannelCode>
<orderItem>
<productCode>AQ7481-002-001</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-002</productCode>
</orderItem>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
</orderHeader>
<orderHeader>
<distributionChannelCode>10</distributionChannelCode>
<orderItem>
<productCode>AQ7481-002-003</productCode>
</orderItem>
</orderHeader>
我不确定我是否理解其中的逻辑,但也许以下方法可以完成任务:按产品代码对orderItems进行分组,以确定哪个组拥有最多的项目,然后从每个组输出尽可能多的orderHeader和相应的项目:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="#all"
version="3.0">
<xsl:mode on-no-match="shallow-copy"/>
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="orderHeader">
<xsl:variable name="groups" as="map(xs:string, element(orderItem)*)*">
<xsl:for-each-group select="orderItem" group-by="string(productCode)">
<xsl:map-entry key="current-grouping-key()" select="current-group()"/>
</xsl:for-each-group>
</xsl:variable>
<xsl:variable name="this" select="."/>
<xsl:variable name="max-items" select="max($groups!count(?*))"/>
<xsl:iterate select="1 to $max-items">
<orderHeader>
<xsl:copy-of
select="$this/distributionChannelCode,
$groups ! ?*[current()]"/>
</orderHeader>
</xsl:iterate>
</xsl:template>
</xsl:stylesheet>