XSLT1.0:Muenchian分组不起作用
我有以下简化的XML结构:XSLT1.0:Muenchian分组不起作用,xslt,xslt-1.0,muenchian-grouping,Xslt,Xslt 1.0,Muenchian Grouping,我有以下简化的XML结构: <?xml version="1.0" encoding="utf-8"?> <list> <INVOIC> <M_INVOIC> <G_SG25> <S_LIN> <id>LIN</id> <D_1082>1</D_1082>
<?xml version="1.0" encoding="utf-8"?>
<list>
<INVOIC>
<M_INVOIC>
<G_SG25>
<S_LIN>
<id>LIN</id>
<D_1082>1</D_1082>
<C_C212>
<D_7140>7610400271943</D_7140>
<D_7143_3>EN</D_7143_3>
</C_C212>
</S_LIN>
</G_SG25>
<G_SG25>
<S_LIN>
<id>LIN</id>
<D_1082>2</D_1082>
<C_C212>
<D_7140>1234567890123</D_7140>
<D_7143_3>EN</D_7143_3>
</C_C212>
</S_LIN>
</G_SG25>
</M_INVOIC>
</INVOIC>
<INVOIC>
<SALESORDER>
<ET_VBAP>
<item>
<VBELN>0010002695</VBELN>
<POSNR>000010</POSNR>
<MATNR>000000000000400487</MATNR>
<EAN11>1234567890123</EAN11>
</item>
<item>
<VBELN>0010002695</VBELN>
<POSNR>000020</POSNR>
<MATNR>000000000000002054</MATNR>
<EAN11>5012454920549</EAN11>
</item>
<item>
<VBELN>0010002695</VBELN>
<POSNR>000030</POSNR>
<MATNR>000000000000392104</MATNR>
<EAN11>3046920921046</EAN11>
</item>
<item>
<VBELN>0010002695</VBELN>
<POSNR>000040</POSNR>
<MATNR>000000000000859146</MATNR>
<EAN11>8003340591469</EAN11>
</item>
<item>
<VBELN>0010002695</VBELN>
<POSNR>000050</POSNR>
<MATNR>000000000000727194</MATNR>
<EAN11>7610400271943</EAN11>
</item>
</ET_VBAP>
</SALESORDER>
</INVOIC>
</list>
林
1.
7610400271943
EN
林
2.
1234567890123
EN
0010002695
000010
000000000000400487
1234567890123
0010002695
000020
000000000000002054
5012454920549
0010002695
000030
000000000000392104
3046920921046
0010002695
000040
000000000000859146
8003340591469
0010002695
000050
000000000000727194
7610400271943
我的XSLT:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:output method="xml" encoding="UTF-8" indent="yes"/>
<xsl:key name="kByEanPos" match="G_SG25" use="S_LIN/C_C212/D_7140"/>
<xsl:template match="/">
<xsl:variable name="uniqueSet" select="G_SG25[generate-id()=generate-id(key('kByEanPos',S_LIN/C_C212/D_7140))]"/>
<list>
<xsl:for-each select="list/INVOIC/M_INVOIC/G_SG25[generate-id()=
generate-id(key('kByEanPos',S_LIN/C_C212/D_7140))]">
<ean>
<xsl:value-of select="parent::M_INVOIC/parent::INVOIC/parent::list/INVOIC/SALESORDER/ET_VBAP/item/MATNR"/>
</ean>
</xsl:for-each>
</list>
</xsl:template>
</xsl:stylesheet>
提供以下XML输出:
<?xml version="1.0" encoding="UTF-8"?>
<list>
<ean>000000000000400487</ean>
<ean>000000000000400487</ean>
</list>
000000000000400487
000000000000400487
但我预期的XML输出是:
<?xml version="1.0" encoding="UTF-8"?>
<list>
<ean>000000000000727194</ean>
<ean>000000000000400487</ean>
</list>
000000000000727194
000000000000400487
我不确定我做错了什么,我找不到我的错误。我认为这与我定义的键有关。
基本上,我需要在
上输入一个键,然后在EAN11
的下面结构中查找该数字,并在前面输出MATNR
谢谢你的建议和问候,
彼得在这一行:
<xsl:value-of
select="parent::M_INVOIC/parent::INVOIC/parent::list/INVOIC/SALESORDER/ET_VBAP/item/MATNR"/>
如果您正试图根据元素的EAN11值查找项元素,可能也值得考虑使用一个键来执行此操作
<xsl:key name="item" match="item" use="EAN11" />
这样,您就可以将xsl:value的值减少到这个值
<xsl:value-of select="key('item', S_LIN/C_C212/D_7140)/MATNR"/>
Hello JLRishe,谢谢您的回答-它可以工作(+1)。不过我更喜欢timc的解决方案,因为它避免了冗长的XPATH。最好的问候,彼得·蒂姆,谢谢你。您的解决方案非常有效。我使用键匹配项和EAN11调整了映射。向你问好,彼得
<xsl:value-of select="key('item', S_LIN/C_C212/D_7140)/MATNR"/>