0

我在使用 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=?>
4

1 回答 1

0

我很难尝试使用 la muenchian 的键进行分组,因为 match 不允许变量:

您不需要在匹配定义中使用变量。将您的关键元素定义为:

<xsl:key name="row-by-site" match="row" use="col[@column-label='Site']"/>

调用 key() 函数时,您必须位于查询创建的“文档”的上下文中 - 否则它将在源 XML 文档中查找要匹配的行。

于 2014-11-24T05:37:18.213 回答