几天,我一直在努力寻找解决这个问题的解决方案。我有这个XML:
<?xml version="1.0" encoding="iso-8859-1"?>
<Einreichung>
<EinreichZahlung>
<EinreichZahlungen>
<MemberFirstName>JOHN</MemberFirstName>
<MemberLastName>DOE</MemberLastName>
<MemberLogin>1</MemberLogin>
<Store>0180</Store>
</EinreichZahlungen>
</EinreichZahlung>
<EinreichZahlung>
<EinreichZahlungen>
<MemberFirstName>DAVID</MemberFirstName>
<MemberLastName>GREEN</MemberLastName>
<MemberLogin>2</MemberLogin>
<Store>0181</Store>
</EinreichZahlungen>
</EinreichZahlung>
<EinreichPerson>
<PersonBelege>
<Belege>
<MemberFirstName>JANE</MemberFirstName>
<MemberLastName>DOE</MemberLastName>
<MemberLogin>1</MemberLogin>
<Store>0180</Store>
</Belege>
<Belege>
<MemberFirstName>JANE</MemberFirstName>
<MemberLastName>DOE</MemberLastName>
<MemberLogin>1</MemberLogin>
<Store>0180</Store>
</Belege>
</PersonBelege>
</EinreichPerson>
<EinreichPerson>
<PersonBelege>
<Belege>
<MemberFirstName>DAVID</MemberFirstName>
<MemberLastName>GREEN</MemberLastName>
<MemberLogin>2</MemberLogin>
<Store>0181</Store>
</Belege>
</PersonBelege>
</EinreichPerson>
</Einreichung>
我需要将两个节点与XSLT合并为基于 Store 值的XSLT,以使最终的HTML看起来像这样:
<pre><b>
Zahlung 1080: JOHN DOE
Belege 1080: details...
Zahlung 1081: DAVID GREEN
Belege 1081: details...
</b></pre>
我是XSLT的新手,所以我将感谢您的帮助。
处理节点时,您可以使用XPath表达式在XML树中找到任何节点。为了加快这一点,最好创建一个键,并将"匹配"属性设置为您要寻找的元素标签,而"使用"属性作为索引。
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" omit-xml-declaration="yes" indent="yes"/>
<xsl:key name="belege-by-store" match="Belege" use="Store" />
<xsl:template match="/Einreichung">
<xsl:apply-templates select="EinreichZahlung/EinreichZahlungen" />
</xsl:template>
<xsl:template match="EinreichZahlungen">
<pre>
<b>
<xsl:value-of select="MemberFirstName" /><xsl:text> </xsl:text>
<xsl:value-of select="MemberLastName" /><xsl:text> </xsl:text>
<xsl:value-of select="key('belege-by-store', Store)/MemberFirstName" />
</b>
</pre>
</xsl:template>
</xsl:stylesheet>
定义变量可能有助于可读性(使用Belege [1],因为您似乎有2个商店的Belege节点,但THQ问题要求合并2个节点)
<xsl:template match="EinreichZahlungen">
<xsl:variable name="belegeNodes">
<xsl:copy-of select="key('belege-by-store', Store)" />
</xsl:variable>
<pre>
<b>
<xsl:value-of select="MemberFirstName" />
<xsl:text> </xsl:text>
<xsl:value-of select="MemberLastName" />
<xsl:text> </xsl:text>
<xsl:value-of select="$belegeNodes/Belege[1]/MemberFirstName" />
</b>
</pre>
</xsl:template>
更新:
您可以使用以下内容来处理每个BELEGE:
<xsl:for-each select="key('belege-by-store', Store)">
<tr><td><xsl:value-of select="MemberFirstName" />
</td></tr>
</xsl:for-each>
或(带有另一个BELEGE的模板)
<xsl:apply-templates select="key('belege-by-store', Store)">