假设是您可以使用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>
当样式表与 Saxon 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>
第username
一个的 themain
现在是空的,因为有一个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>