需要从XML输入和XSL执行输出以创建XML输出

时间:2016-08-15 11:02:07

标签: xml xslt

我编写了以下xml代码作为输入,并转到xslt脚本,该脚本将处理xml代码以生成xml输出:

XML输入

user_id

<TAB512> <WA>f1,f2</WA> </TAB512> <TAB512> <WA>df1,df2</WA> </TAB512> </DATA> <FIELDS> <Filed> <FIELDNAME>Field1</FIELDNAME> </Filed> <Filed> <FIELDNAME>Field2</FIELDNAME> </Filed> </FIELDS> </Response> 中第一个元素<WA>中的第一个元素 xsl脚本将格式化输入xml以生成xml输出

<FIELDNAME>

我的意思是','之前的第一个元素将是Field1的第一个元素和','之后的元素

XSL脚本

<TAB512>
<WA>f1,f2</WA>
</TAB512>

最后

需要这样的XML输出:

    <xsl:template name="WriteRecordNodeTemplate">
<xsl:param name="Field" />
<xsl:param name="WA" />

<Response>
<xsl:call-template name="StringSplit">
<xsl:with-param name="fi" select="$Field" />
<xsl:with-param name="w" select="$WA" />
</xsl:call-template>
</Response>
</xsl:template>

<xsl:template name="StringSplit">
<xsl:param name="fi" />
<xsl:param name="w" />
<xsl:choose>
  <xsl:when test="contains($w, ',')">
<Record>
   <xsl:value-of select="$fi" ><xsl:value-of select="substring-before($w, ',')" /></xsl:value-of select="$fi" >
</Record>

     <xsl:call-template name="StringSplit">
     <xsl:param name="fi" />
     <xsl:with-param name="w" select="substring-after($w, ',')" />
     </xsl:call-template>

  </xsl:when>
  <xsl:otherwise>
      <!-- if there is no more delimiter values, print out 
the whole string -->
<Record>
<xsl:value-of select="$fi" ><xsl:value-of select="$w" /></xsl:value-of select="$fi" >
</Record>
   </xsl:otherwise>
</xsl:choose>

</xsl:template>

1 个答案:

答案 0 :(得分:0)

我猜你想做:

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:variable name="field-names" select="/Response/FIELDS/Filed" />

<xsl:template match="/Response">
    <TableName>
        <xsl:for-each select="DATA/TAB512">
            <Record>
                <xsl:call-template name="tokenize">
                    <xsl:with-param name="text" select="WA"/>
                </xsl:call-template>
            </Record>
        </xsl:for-each>
    </TableName>
</xsl:template>

<xsl:template name="tokenize">
    <xsl:param name="text"/>
    <xsl:param name="delimiter" select="','"/>
    <xsl:param name="i" select="1"/>
        <xsl:variable name="token" select="substring-before(concat($text, $delimiter), $delimiter)" />
        <xsl:if test="$token">
            <xsl:element name="{$field-names[$i]/FIELDNAME}">
                <xsl:value-of select="$token"/>
            </xsl:element>
        </xsl:if>
        <xsl:if test="contains($text, $delimiter)">
            <!-- recursive call -->
            <xsl:call-template name="tokenize">
                <xsl:with-param name="text" select="substring-after($text, $delimiter)"/>
                <xsl:with-param name="i" select="$i + 1"/>
            </xsl:call-template>
        </xsl:if>
</xsl:template>

</xsl:stylesheet>

应用于以下测试输入:

<强> XML

<Response>
  <DATA>
    <TAB512>
      <WA>a1,b1</WA>
    </TAB512>
    <TAB512>
      <WA>a2,b2</WA>
    </TAB512>
  </DATA>
  <FIELDS>
    <Filed>
      <FIELDNAME>ColumnA</FIELDNAME>
    </Filed>
    <Filed>
      <FIELDNAME>ColumnB</FIELDNAME>
    </Filed>
  </FIELDS>
</Response>

结果将是:

<?xml version="1.0" encoding="UTF-8"?>
<TableName>
   <Record>
      <ColumnA>a1</ColumnA>
      <ColumnB>b1</ColumnB>
   </Record>
   <Record>
      <ColumnA>a2</ColumnA>
      <ColumnB>b2</ColumnB>
   </Record>
</TableName>

请注意,这需要FIELDNAME值作为有效的XML名称。它还假定每个WA元素具有与Filed个节点数相同的逗号分隔值。

还假设您的输入拼错了Filed,如示例所示。