XSLT 1.0:使用键的简单解决方案:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:key name="kNameByVal" match="name" use="."/>
<xsl:template match="/*">
Your duplicate strings are: <xsl:text/>
<xsl:apply-templates select=
"b/name[generate-id() = generate-id(key('kNameByVal', .)[2])]"/>
</xsl:template>
<xsl:template match="name">
<xsl:if test="position() >1">, </xsl:if>
<xsl:value-of select="."/>
</xsl:template>
<xsl:template match="text()"/>
</xsl:stylesheet>
二、XSLT 2.0 解决方案:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:variable name="vSeq" select="data(/a/b/name)"/>
<xsl:template match="/">
Your duplicate strings are: <xsl:text/>
<xsl:sequence select="$vSeq[index-of($vSeq,.)[2]]"/>
</xsl:template>
</xsl:stylesheet>
三、XPath 2.0 单行
$vSeq[index-of($vSeq,.)[2]]
这将产生给定序列中的所有值,这些值具有重复项(一组重复项中的一个)。