假設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