我的输入XML如下,
<OUTPUT-AREA><TIME-CD>A</TIME-CD>
<ID-G>
<Table-ID-T>
<AT-ID-T>YYYX</AT-ID-T>
<AT-ID-T/>
<AT-ID-T/>
</Table-ID-T>
</ID-G>
</OUTPUT-AREA>
我的输出 XML shoule 就像,
<OUTPUT-AREA>
<TIME-CD>A</TIME-CD>
<ID-G>
<Table-ID-T>
<AT-ID-T>YYYX</AT-ID-T>
</Table-ID-T>
</ID-G>
</OUTPUT-AREA>
我只想删除具有空值的子元素。在上面的示例中,我只想删除具有空值的<AT-ID-T>
元素。
但不应删除表 ID-T 或 ID-G。
这里的一个挑战是,假设如果所有子元素都具有空值,那么至少一个子元素应该保留在表或数组中。
例如,输入 XML 是
<OUTPUT-AREA>
<TIME-CD>A</TIME-CD>
<ID-G>
<Table-ID-T>
<AT-ID-T/>
<AT-ID-T/>
<AT-ID-T/>
</Table-ID-T>
</ID-G>
</OUTPUT-AREA>
那么输出应该是这样的,
<OUTPUT-AREA>
<TIME-CD>A</TIME-CD>
<ID-G>
<Table-ID-T>
<AT-ID-T/>
</Table-ID-T>
</ID-G>
</OUTPUT-AREA>
请为我提供符合要求的合适 XSLT。
请在下面找到我尝试过的 XSLT,
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns="http://ACORD.org/Standards/Life/2">
<xsl:output encoding="UTF-8" indent="no" omit-xml-declaration="no"/>
<xsl:template match="/">
<xsl:apply-templates select="*"/>
</xsl:template>
<xsl:template match="*">
<xsl:if test=".!=''">
<xsl:copy>
<xsl:copy-of select="@*"/>
<xsl:apply-templates/>
</xsl:copy>
</xsl:if>
</xsl:template>
在应用上述 XSLT 时,删除了所有具有空值的元素。但是我只需要删除子元素。
假设你知道空元素的名称(例如 AT-ID-T
) 您要删除然后使用
<xsl:transform xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0">
<xsl:output indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="Table-ID-T[not(AT-ID-T[normalize-space()])]/AT-ID-T[position() > 1]
| Table-ID-T[AT-ID-T[normalize-space()]]/AT-ID-T[not(normalize-space())]"/>
</xsl:transform>
一个输入样本的在线 http://xsltransform.net/ej9EGcX 示例和另一个输入样本的 http://xsltransform.net/ej9EGcX/2 示例。
我尝试了以下方法及其工作:
<xsl:template match="node()[.='']"/>
<xsl:template match="Table-ID-T/*[1]">
<xsl:copy-of select="."/>
</xsl:template>