<document>
<body>
<p>
<pPr>
<autoSpaceDE/>
<autoSpaceDN/>
<adjustRightInd/>
<spacing/>
<rPr>
<rFonts/>
<b/>
<bCs/>
<lang/>
</rPr>
</pPr>
<r>
<rPr>
<rFonts/>
<b/>
<bCs/>
<lang/>
</rPr>
<t>Title</t>
</r>
</p>
</body>
</document>
如何在不影响或删除其中文本的情况下删除某些标签这是我在 XSLT 之后的预期输出
<document><body><p>Title</p></body></document>
你可以使用这个:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="p">
<xsl:copy>
<xsl:value-of select="normalize-space(.)"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
基本上,您可以遵循以下两种策略之一:
-
从将所有内容复制为默认值的身份转换模板开始; 然后添加模板以匹配要修改的任何节点作为例外;这就是你开始做的事情 - 现在你只需要添加空模板来删除你不需要的节点。
-
只选择你想要的节点;因为只有一个节点,所以在这种情况下,这将是迄今为止的首选策略:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/">
<p>
<xsl:value-of select="document/body/p/r/t" />
</p>
</xsl:template>
</xsl:stylesheet>
返回以下结果:
<?xml version="1.0" encoding="UTF-8"?>
<p>Title</p>
以上假设您实际上想要 <t>
元素的特定值 - 而不仅仅是碰巧是输入的<p>
元素的后代的任何文本节点。如果此假设不正确,请改为执行以下操作:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="/">
<p>
<xsl:value-of select="document/body/p" />
</p>
</xsl:template>
</xsl:stylesheet>
的答案,对我有好处
<xsl:template match="//*/text()">
<xsl:if test="normalize-space(.)">
<xsl:value-of select=
"concat(normalize-space(.), '
')"/>
</xsl:if>
<xsl:apply-templates />
</xsl:template>
我使用了这个,现在我的问题是如何删除具有空值的标签
<p/>
转换后如何消除该标记?谢谢