-1

我正在尝试通过 xslt 转换从 XML 文件生成 csv 文件。xml文件的开头:

 <?xml version="1.0" encoding="UTF-8"?>
    <Document xmlns="urn:iso:std:iso:20022:tech:xsd:camt.054.001.02"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <BkToCstmrDbtCdtNtfctn>
    <GrpHdr>
            <MsgId>UPDD2021-12-20-18.26.01.660000</MsgId>
            <CreDtTm>2021-12-20T18:26:01</CreDtTm>
    </GrpHdr>
    ...
</BkToCstmrDbtCdtNtfctn>
    </Document>

转换文件:

    <?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:camt.054.001.02" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<xsl:output indent="yes" method="text"/>
<xsl:variable select="';'" name="delimiter"/>
<xsl:variable name="newline">
<xsl:text> 
</xsl:text>
</xsl:variable>
<xsl:template match="/">
<xsl:for-each select="BkToCstmrDbtCdtNtfctn/Ntfctn/Ntry/NtryDtls/TxDtls">
    <xsl:value-of select="../../../../GrpHdr/MsgId"/>
    <xsl:value-of select="$delimiter"/>
    <xsl:value-of select="../../../../Ntfctn/CreDtTm"/>
    <xsl:value-of select="$delimiter"/>
    <xsl:value-of select="$newline"/>
</xsl:for-each>
</xsl:template>
</Document>
</xsl:stylesheet>

但是 csv 文件没有按预期生成,因为它看起来像这样(每条记录都在新行上):

        UPDD2021-12-20-18.26.01.660000
        2021-12-20T18:26:01
    
    
        003409153772021-12-20-18.26.01.9625
        2021-12-20T18:26:01

当我从两个文件中删除标签Document>时,它看起来正确(添加了';'并且每个都在一行上):

UPDD2021-12-20-18.26.01.660000;2021-12-20T18:26:01;

有人知道如何更新转换文件以使 csv 看起来正确吗?

问题已解决。正确的变换:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:camt="urn:iso:std:iso:20022:tech:xsd:camt.054.001.02"
          exclude-result-prefixes="camt">
<xsl:output indent="yes" method="text"/>
<xsl:variable select="';'" name="delimiter"/>
<xsl:variable name="newline">
<xsl:text> 
</xsl:text>
</xsl:variable>
<xsl:template match="/">
<xsl:for-each select="camt:Document/camt:BkToCstmrDbtCdtNtfctn/camt:Ntfctn/camt:Ntry/camt:NtryDtls/camt:TxDtls">
    <xsl:value-of select="../../../../camt:GrpHdr/camt:MsgId"/>
    <xsl:value-of select="$delimiter"/>
    <xsl:value-of select="../../../../camt:Ntfctn/camt:CreDtTm"/>
    <xsl:value-of select="$delimiter"/>
<xsl:value-of select="$newline"/>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
4

2 回答 2

0

如果</Document>结束标记出现在样式表的末尾(您没有向我们展示),那么您的所有 XSLT 代码都在顶级数据元素中,这相当于将其注释掉。结果是您在源文档上执行了“空样式表”,这将复制源文档中的文本节点并忽略其他所有内容。

于 2021-12-29T10:51:53.373 回答
0

对于 XSLT 2 或 3 处理器,您希望xpath-default-namespace=""urn:iso:std:iso:20022:tech:xsd:camt.054.001.02"xsl:stylesheet元素上声明,然后在 XSLT 代码中编写路径,您可以在其中使用输入文档中的本地元素名称。Anyxsl:template必须是xsl:stylesheet.

对于 XSLT 1 处理器,您需要将名称空间 URI 绑定到 XSLT 中的前缀(例如xmlns:camt="urn:iso:std:iso:20022:tech:xsd:camt.054.001.02"),并使用该前缀来限定路径表达式中的任何元素名称。

于 2021-12-29T11:57:17.720 回答