我的输出看起来像
<TransactionLog TID="1400" SeqNo="3337446" SQLTransaction="Insert into TankerLoads Values(141221,53,299,18,1,426148,6,'Nov 19 2007 12:00AM','Dec 30 1899 12:59PM',3.00,20682,0,'Zevo','Nov 19 2007 12:00AM',0)" />
我需要添加<root>
节点,以便它看起来像下面的
<root>
<TransactionLog TID="1400" SeqNo="3337446" SQLTransaction="Insert into TankerLoads Values(141221,53,299,18,1,426148,6,'Nov 19 2007 12:00AM','Dec 30 1899 12:59PM',3.00,20682,0,'Zevo','Nov 19 2007 12:00AM',0)" />
</root>
我使用下面的代码组合了所有记录,现在我需要添加根节点,我需要使用OUTPUT METHOD AS TEXT来显示它。请帮帮我。
<xsl:template match="text()">
<xsl:value-of select="normalize-space(.)" />
</xsl:template>
答案 0 :(得分:0)
您可以在变量中捕获转换的输出,并将变量的内容应用于与此类似的转换:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:variable name="vResult1">
<TransactionLog TID="1400"
SeqNo="3337446"
SQLTransaction="Insert into TankerLoads Values(141221,53,299,18,1,426148,6,'Nov 19 2007 12:00AM','Dec 30 1899 12:59PM',3.00,20682,0,'Zevo','Nov 19 2007 12:00AM',0)" />
</xsl:variable>
<xsl:template match="node()|@*" mode="pass2">
<xsl:copy>
<xsl:apply-templates select="node()|@*" mode="pass2"/>
</xsl:copy>
</xsl:template>
<xsl:template match="/">
<root>
<xsl:apply-templates select="$vResult1/*" mode="pass2"/>
</root>
</xsl:template>
</xsl:stylesheet>
对任何XML文档(未使用)执行此转换时,会生成所需的正确结果:
<root>
<TransactionLog TID="1400" SeqNo="3337446"
SQLTransaction="Insert into TankerLoads Values(141221,53,299,18,1,426148,6,'Nov 19 2007 12:00AM','Dec 30 1899 12:59PM',3.00,20682,0,'Zevo','Nov 19 2007 12:00AM',0)"/>
</root>
或者,更好的是,将您现有的转化修改为以下内容:
<xsl:template match="/">
<root>
<xsl:apply-templates/>
</root>
</xsl:template>
或者,如果您的转化已经有匹配/
的模板:
<xsl:template match="/">
<root>
<!-- Put the body of your current template here -->
</root>
</xsl:template>
</xsl:stylesheet>