在下面的示例中,xml ASNOutDesc可以有多个ASNOutDistro,每个ASNOutDistro可以有多个ASNOutCtn,在每个ASNOutCtn下可以有多个ASNOutItem,每个ASNOutCtn下的所有项必须合并,并且必须添加unit_qty。我尝试使用下面的xslt,但它是merg
输入XML:
<ASNoutDesc>
<ASNOutDesc>
<to_location>14</to_location>
<from_location>777</from_location>
<asn_nbr>Bol1</asn_nbr>
<container_qty>3</container_qty>
<shipment_date>2012-04-20T15:37:30.757</shipment_date>
<ASNOutDistro>
<distro_nbr>101</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>1</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</ASNOutDistro>
<ASNOutDistro>
<distro_nbr>102</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>2</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
</ASNOutCtn>
<ASNOutCtn>
<container_id>3</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</ASNOutDistro>
</ASNOutDesc>
</ASNoutDesc>
必填项:
<ASNoutDesc>
<ASNOutDesc>
<to_location>14</to_location>
<from_location>777</from_location>
<asn_nbr>Bol1</asn_nbr>
<container_qty>3</container_qty>
<shipment_date>2012-04-20T15:37:30.757</shipment_date>
<ASNOutDistro>
<distro_nbr>101</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>1</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>4</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</ASNOutDistro>
<ASNOutDistro>
<distro_nbr>102</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>2</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>4</unit_qty>
</ASNOutItem>
</ASNOutCtn>
<ASNOutCtn>
<container_id>3</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>2</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</ASNOutDistro>
</ASNOutDesc>
</ASNoutDesc>
如上所示,它必须合并每个ASNOutDistro下的每个ASNOutCtn中的项目。
XSLT Iam使用:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="kByI" match="ASNOutItem" use="item_id"/>
<xsl:template match="node()|@*">
<xsl:param name="pNewValueQty"/>
<xsl:copy>
<xsl:apply-templates select="node()|@*">
<xsl:with-param name="pNewValueQty" select="$pNewValueQty"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
<xsl:template match="ASNOutItem[generate-id()=generate-id(key('kByI',item_id)[1])]">
<xsl:copy>
<xsl:apply-templates select="node()|@*">
<xsl:with-param name="pNewValueQty" select="sum(key('kByI',item_id)/unit_qty)"/>
</xsl:apply-templates>
</xsl:copy>
</xsl:template>
<xsl:template match="ASNOutItem"/>
<xsl:template match="unit_qty/text()">
<xsl:param name="pNewValueQty"/>
<xsl:value-of select="$pNewValueQty"/>
</xsl:template>
</xsl:stylesheet>
我得到的输出:
<ASNoutDesc>
<ASNOutDesc>
<to_location>14</to_location>
<from_location>777</from_location>
<asn_nbr>Bol1</asn_nbr>
<container_qty>3</container_qty>
<shipment_date>2012-04-20T15:37:30.757</shipment_date>
<ASNOutDistro>
<distro_nbr>101</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>1</container_id>
<ASNOutItem>
<item_id>item-1</item_id>
<unit_qty>8</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</ASNOutDistro>
<ASNOutDistro>
<distro_nbr>102</distro_nbr>
<distro_doc_type>A</distro_doc_type>
<ASNOutCtn>
<container_id>2</container_id>
<ASNOutItem>
<item_id>item-2</item_id>
<unit_qty>6</unit_qty>
</ASNOutItem>
</ASNOutCtn>
<ASNOutCtn>
<container_id>3</container_id>
</ASNOutCtn>
</ASNOutDistro>
</ASNOutDesc>
</ASNoutDesc>
- 我的代码正在合并xml中的所有项目。请帮助我获取所需的输出。
提前致谢。
答案 0 :(得分:0)
出错的地方是忘记考虑ASNOutItem节点分组中的父节点。您的密钥定义应该以item_id和ASNOutCtn节点为主,该节点是ASNOutItem的父节点,因为分组不会跨越ASNOutCtn边界。
这个样式表是你想要的......
<?xml version="1.0" encoding="utf-8"?>
<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:key name="kByI" match="ASNOutItem" use="concat(item_id,'+',generate-id(parent::*))"/>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="ASNOutCtn">
<xsl:copy>
<xsl:apply-templates select="@*"/>
<xsl:apply-templates select="node()[not(self::ASNOutItem)]"/>
<xsl:apply-templates
select="ASNOutItem[
generate-id(.) =
generate-id( key('kByI',concat(item_id,'+',generate-id(parent::*)))[1])]"
mode="merge"/>
</xsl:copy>
</xsl:template>
<xsl:template match="ASNOutItem" mode="merge">
<xsl:copy>
<xsl:apply-templates select="@*"/>
<xsl:apply-templates select="node()[not(self::unit_qty)]"/>
<unit_qty>
<xsl:value-of select="sum(
key('kByI',concat(item_id,'+',generate-id(parent::*)))/unit_qty)" />
</unit_qty>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
答案 1 :(得分:-1)
为什么不使用sum(ASNOutItem/item_id)
?
很抱歉,如果我问,但在我看来,如果我在一年内查看该代码,将花费大量时间来了解我做了什么以及它做了什么。我宁愿做类似的事情:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<ASNoutDesc>
<ASNOutDesc>
<xsl:copy-of select="*[name() != 'ASNOutDistro']"/>
<xsl:for-each select="ASNOutDistro">
<xsl:copy-of select="*[name() != 'ASNOutCtn']"/>
<xsl:for-each select="ASNOutCtn">
<ASNOutCtn>
<xsl:copy-of select="*[name() != 'ASNOutItem']"/>
<ASNOutItem>
<xsl:copy-of select="ASNOutItem[1]/*[name() != 'unit_qty']"/>
<unit_qty>
<xsl:value-of select="sum(ASNOutItem/*/unit_qty)"/>
</unit_qty>
</ASNOutItem>
</ASNOutCtn>
</xsl:for-each>
</xsl:for-each>
</ASNOutDesc>
</ASNoutDesc>