我编写了以下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>
答案 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
,如示例所示。