假设foo
是main
元素的父元素的名称可以使用
<xsl:stylesheet
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="2.0">
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* , node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="foo[some $m in main satisfies $m/username != main/username]/main[1]/username">
<xsl:copy/>
</xsl:template>
</xsl:stylesheet>
下面是一些输入样本:
<root>
<foo>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u1</username>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u1</username>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u2</username>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u1</username>
<address/>
</main>
</foo>
</root>
当样式表应用撒克逊9.4,我得到的输出是
<root>
<foo>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username/>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u1</username>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u2</username>
<address/>
</main>
<main>
<input1/>
<input2/>
<input3/>
<input4/>
<input5/>
<inside/>
<username>u1</username>
<address/>
</main>
</foo>
</root>
,其中第一main
的username
现在是空的,因为有一个main
有username
是从其他的不同。
由于答案已被接受,我有点困惑,但评论说你需要一个XSLT 1.0解决方案。我将在下面提供一个XSLT 1.0样式表:
<xsl:stylesheet
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="foo[main[username != ../main/username]]/main[1]/username">
<xsl:copy/>
</xsl:template>
</xsl:stylesheet>
使用XSLT 1.0或XSLT 2.0? – 2013-02-14 10:18:45
您已将此标记为xslt 1.0和2.0 - 您确实需要哪一个? – 2013-02-14 10:19:04