0

我的输出看起来像

<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>
4

1 回答 1

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>
于 2012-07-09T00:01:16.780 回答