XSLT 1.0 中唯一可移植的分组方法是 Muenchian 方法,其核心是通过 定义键并结合 generate-id() 识别每组首个节点,再用 key() 获取同组全部节点。

XSLT 2.0 的 <for-each-group></for-each-group> 配合 group-by 是最直观的分组方式,而 XSLT 1.0 没有原生分组指令,必须用 Muenchian 方法模拟——它不是“替代方案”,而是 XSLT 1.0 中唯一被广泛验证、可移植的等效实现。
Muenchian 分组本质是两步走:先定义键(<key></key>),再筛选每个键值下第一个匹配节点。只有这个“首个节点”才触发分组逻辑,其余同组节点通过 key() 函数批量获取。
<key name="k" match="book" use="author"></key> 建立“作者 → 所有 book 元素”的映射book[generate-id() = generate-id(key('k', author)[1])] 找出每个作者第一次出现的 bookkey('k', author) 拿到全部同作者书籍以下是最简可用骨架,适配任意 XML 结构:
<xsl:key name="by-author" match="book" use="author"/>
<xsl:template match="/">
<div>
<!-- 步骤1:遍历每个唯一 author(即每组的代表节点)-->
<xsl:for-each select="library/book[generate-id() = generate-id(key('by-author', author)[1])]>
<h3><xsl:value-of select="author"/></h3>
<ul>
<!-- 步骤2:取出该 author 下所有 book -->
<xsl:for-each select="key('by-author', author)">
<li><xsl:value-of select="title"/></li>
</xsl:for-each>
</ul>
</xsl:for-each>
</div>
</xsl:template>实际使用时需注意几个易错点:
use="@category"(按属性)、use="concat(substring(title,1,1), '-group')"(首字母分组)use="normalize-space(author) | 'unknown'" 避免生成空组key() 内部再加 position() mod 2 等判断,会显著拖慢虽然功能等价,但行为不完全一致:
<sort></sort> 可显式控制组序count(key('k', author)) 手动统计;2.0 有 current-group() 和 current-grouping-key()
以上就是XSLT 2.0中的group-by怎么用 Muenchian分组法替代方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号