XSLT分割一个用逗号分隔的长字符串值

时间:2019-06-02 17:13:30

标签: xml xslt

我有一个具有此内容的输入xml

/persons/<id>

每个<BankStatementAccount> <Line> <Data>TEST,,TEST,,,</Data> </Line> <Line> <Data>,,,,,</Data> </Line> <Line> <Data>Account:,TEST,TEST,,,</Data> </Line> <Line> <Data>,,,,,</Data> </Line> <Line> <Data>Payment Date:,1/5/2019,,,,</Data> </Line> <Line> <Data>,,,,,</Data> </Line> <Line> <Data>Payment No:,123456,,,,</Data> </Line> <Line> <Data>,,,,,</Data> </Line> <Line> <Data>11/01/19,crnote,088-543215432,(48.47),(3.39),(45.08) </Data> </Line> <Line> <Data>05/02/19,crnote,033-123456789,(10.09),(0.71),(9.38) </Data> </Line> <Line> <Data>,,,,,</Data> </Line> <Line> <Data>,,Amount Paid,"133,654.70","9,356.10 ","124,298.60 " </Data> </Line> <Line> <Data>,,,,,</Data> </Line> </BankStatementAccount> 字符串值都有6个数据值,以5个逗号分隔。 我需要能够将它们分割在各自的标签上。

看起来像这样:

来自:<Line>

收件人:

<Line>05/02/19,cr note,033-123456789,(10.09),(0.71),(9.38)</Line>

我尝试过

<Line> 
    <tag1>05/02/19</tag1>
    <tag2>cr note</tag2>
    <tag3>033-123456789</tag3>
    <tag4>(10.09)</tag4>
    <tag5>(0.71)</tag5>
    <tag6>(9.38)</tag6>
</Line>

但我不断收到此错误

  

FATAL ERROR:'错误检查表达式的类型   'filter-expr(variable-ref(var / string),[pred(int-expr(1))])'。'

我尝试使用substring(。,1,8)首先查看是否可以从位置1-8获得字符,但是我似乎无法运行它。

我将不胜感激。

谢谢。

1 个答案:

答案 0 :(得分:0)

如果可以使用支持XSL 2.0的处理器,请尝试以下操作:

XSLT 2.0

<xsl:stylesheet version="2.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="*"/>

<!-- identity transform -->
<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="Line">
    <xsl:copy>
        <xsl:for-each select="tokenize(Data, ',')">
            <xsl:element name="tag{position()}">
                <xsl:value-of select="."/>
            </xsl:element>
        </xsl:for-each>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>