如何删除 headers 并且在不满足特定条件时不产生输出

how to remove headers and produce no output when specific condition is not met

我有 XML 数据,我使用 XSLT 从 XML 转换为输出 csv 格式的文本。它在满足过滤条件时生成输出。我现在需要代码在不满足过滤条件时停止生成任何输出。目前不满足过滤条件时生成header

我尝试设置全局变量但出现错误。

<xsl:output method="text" omit-xml-declaration="yes" indent="no"/>
<xsl:strip-space elements="*"/>
<xsl:variable name="delimiter" select="','"/>
<xsl:param name="xslt.transform.params"></xsl:param>
<xsl:variable name="countryCode">
    <xsl:value-of select="$xslt.transform.params"/>
</xsl:variable>
<csv:columns>
    <column>ORIG</column>
    <column>CUST</column>
    <column>PARTY</column>
    <column>ACCOUNT1</column>
    <column>ACCOUNT2</column>
    <column>CURRENCY</column>
    <column>SUM1</column>
    <column>SUM2</column>
    <column>SUM3</column>
    <column>SUM4</column>
    <column>SUM5</column>
    <column>SUM6</column>
    <column>SUM7</column>
    <column>SUM8</column>
    <column>SUM9</column>
    <column>SUM10</column>
    <column>SUM11</column>
    <column>SUM12</column>
</csv:columns>
<xsl:template match="/">
    <xsl:for-each select="document('')/*/csv:columns/*">
        <xsl:value-of select="."/>
        <xsl:if test="position() != last()">
            <xsl:value-of select="$delimiter"/>
        </xsl:if>
    </xsl:for-each>
    <xsl:text>&#xa;</xsl:text>
    <xsl:apply-templates select="*"/>
</xsl:template>
<xsl:template match="/DATA/G">
    <xsl:variable name="result" select="."/>
    <xsl:variable name="orgsysref" select="ORIG"/>
    <xsl:for-each select="document('')/*/csv:columns/*">
        <xsl:variable name="vCountry" select="fn:substring($orgsysref,1,2)"/>
        <xsl:if test="$vCountry = fn:substring-before($countryCode,'|') or $vCountry = fn:substring-after($countryCode, '|') or $vCountry = $countryCode">
            <xsl:variable name="column" select="."/>
            <xsl:variable name="value" select="$result/*[name() = $column]"/>
            <xsl:value-of select="$value"/>
            <xsl:if test="position() != last()">
                <xsl:value-of select="$delimiter"/>
            </xsl:if>
        </xsl:if>
    </xsl:for-each>
    <xsl:text>&#xa;</xsl:text>
</xsl:template>

我试过添加全局变量。

但出现错误:出现错误以匹配所需的序列类型

<xsl:template match="/">
        <xsl:variable name="sysref" select="/DATA/G/ORIG"/>
        <xsl:variable name="country">
            <xsl:value-of select="fn:substring($sysref,1,2)"/>
        </xsl:variable>
        <xsl:choose>
            <xsl:when test="$countryCode != '' and $country = $countryCode">
                <xsl:for-each select="document('')/*/csv:columns/*">
                    <xsl:value-of select="."/>
                    <xsl:if test="position() != last()">
                        <xsl:value-of select="$delimiter"/>
                    </xsl:if>
                </xsl:for-each>
                <xsl:text>&#xa;</xsl:text>
                <xsl:apply-templates select="*"/>

国家代码不匹配时不应生成任何输出。当它匹配时输出应该是:

test107015196,300000011997776,preet,0432007015196,preet,EUR,440.26,3,0,0,16.66,1,423.6,2,0,0,0,0
test100330125,300000013609676,Margarethe Krögner,0432000330125,Margarethe Krögner,EUR,88.73,1,0,0,88.73,1,0,0,0,0,0,0
test107015561,300000013996996,smith,0432007015561,smith,EUR,239.94,1,0,0,239.94,1,0,0,0,0,0,0

不匹配时,不输出。

请帮忙。谢谢。

变量可以简单地具有所需的谓词,例如

<xsl:variable name="data-to-be-processed" select="/DATA/G[substring(ORIG,1,2) = $countryCode]"/>

然后在需要的地方使用它,例如

<xsl:if test="$data-to-be-processed">
  <!-- output header -->
  ...
  <xsl:apply-templates select="$data-to-be-processed"/>
</xsl:if>