更新以利用更简洁的谓词 - 感谢@SeanB.Durkin。
一、XSLT 1.0 解决方案
当这个 XSLT:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:output omit-xml-declaration="no" indent="yes" />
<xsl:strip-space elements="*" />
<xsl:key name="kChapters" match="page" use="." />
<xsl:template match="/*">
<book>
<xsl:apply-templates
select="page[generate-id() = generate-id(key('kChapters', .)[1])]" />
</book>
</xsl:template>
<xsl:template match="page">
<xsl:copy-of select=".|key('kChapters', .)[last()]" />
</xsl:template>
</xsl:stylesheet>
...应用于原始 XML:
<book>
<page number="1">Chapter01</page>
<page number="2">Chapter01</page>
<page number="3">Chapter01</page>
<page number="4">Chapter01</page>
<page number="5">Chapter01</page>
<page number="6">Chapter01</page>
<page number="7">Chapter02</page>
<page number="8">Chapter02</page>
<page number="9">Chapter02</page>
<page number="10">Chapter02</page>
<page number="11">Chapter02</page>
<page number="12">Chapter02</page>
<page number="13">Chapter03</page>
<page number="14">Chapter03</page>
<page number="15">Chapter03</page>
<page number="16">Chapter03</page>
<page number="17">Chapter03</page>
<page number="18">Chapter03</page>
</book>
...产生了预期的结果:
<?xml version="1.0"?>
<book>
<page number="1">Chapter01</page>
<page number="6">Chapter01</page>
<page number="7">Chapter02</page>
<page number="12">Chapter02</page>
<page number="13">Chapter03</page>
<page number="18">Chapter03</page>
</book>
解释:
- 请注意正确使用
Muenchian Grouping
来确定唯一<page>
元素的值。
- 对于每个唯一
<page>
元素,复制两个<page>
元素:包含唯一值的组中的第一个元素和最后一个元素。
二、XSLT 2.0 解决方案
请注意,在 XSLT 2.0 中,解决方案变得更加简单。
当这个 XSLT:
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="2.0">
<xsl:output omit-xml-declaration="no" indent="yes" />
<xsl:strip-space elements="*" />
<xsl:template match="/*">
<book>
<xsl:for-each-group select="page" group-by=".">
<xsl:copy-of select=".|current-group()[last()]" />
</xsl:for-each-group>
</book>
</xsl:template>
</xsl:stylesheet>
...应用于原始 XML,产生相同的期望结果:
<?xml version="1.0"?>
<book>
<page number="1">Chapter01</page>
<page number="6">Chapter01</page>
<page number="7">Chapter02</page>
<page number="12">Chapter02</page>
<page number="13">Chapter03</page>
<page number="18">Chapter03</page>
</book>
解释:
- 应用了相同的方法,但使用了 XSLT 2.0 的
for-each-group
元素和current-group()
指令,而不是 Muenchian Grouping。