我在使用 XSLT 进行动态分组时遇到问题。
我的问题很复杂(我认为),部分原因是我要转换的节点集是从 apache xalan/sql 扩展动态生成的。我密切关注文档站点上的示例:请参阅链接。
XSLT 项目很大;我只包括了以下要点:
<xsl:template match="/">
<!-- I omitted the connection management code -->
<xsl:variable name="result" select="sql:query($connection, $query)"/>
<xsl:apply-templates select="$result/sql/row-set"/>
</xsl:template>
<xsl:template match="row">
<xsl:apply-templates select="col"/>
</xsl:template>
<xsl:template match="col">
<xsl:value-of select="text()"/>
</xsl:template>
$result节点集具有以下结构:
<sql>
<row-set>
<row>
<col column-label='Name'>Bob</col>
<col column-label='Site'>Site1</col>
<col column-label='Active'>Yes</col>
</row>
<row>
<col column-label='Name'>Sally</col>
<col column-label='Site'>Site2</col>
<col column-label='Active'>Yes</col>
</row>
<row>
<col column-label='Name'>Sam</col>
<col column-label='Site'>Site1</col>
<col column-label='Active'>No</col>
</row>
<row>
<col column-label='Name'>Jeff</col>
<col column-label='Site'>Site2</col>
<col column-label='Active'>Yes</col>
</row>
</row-set>
</sql>
期望的结果:
<sql>
<row-set>
<site>
<site-name>Site1</site-name>
<active>
<name>Bob</name>
</active>
<in-active>
<name>Sam</name>
</in-active>
</site>
<site>
<site-name>Site2</site-name>
<active>
<name>Sally</name>
<name>Jeff</name>
</active>
<in-active/>
</site>
</row-set>
</sql>
我很难尝试使用 la muenchian 的键进行分组,因为match不允许变量:
<xsl:key name="group-site" match="$result/sql/row-set/" use=?>