以下是我的输入xml
<ServiceIncident xmlns="http://b2b.ibm.com/schema/IS_B2B_CDM/R2_2">
<RequesterID/>
<ProviderID>INC0011731</ProviderID>
<ProviderPriority>4</ProviderPriority>
<WorkflowStatus>NEW</WorkflowStatus>
<Transaction>
<Acknowledge>1</Acknowledge>
<StatusCode>0</StatusCode>
<Comment>String</Comment>
<TransactionName>Problem_Submittal</TransactionName>
<TransactionType>2</TransactionType>
<TransactionDateTime>2012-10-19T16:05:56Z</TransactionDateTime>
<TransactionNumber>2012-10-19T16:05:56Z:1ae9b6a79901fc40fa75c64e1cdcc3b4</TransactionNumber>
<TransactionRouting>MX::ITELLASNINCBRDG</TransactionRouting>
<DataSource>ServiceNow</DataSource>
<DataTarget>NASPGR72</DataTarget>
</Transaction>
</ServiceIncident>
我的要求是我需要将整个输入复制为输出,但输入中的一个字段需要在输出中更改。
以下是我在xslt中用来复制输入的代码。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:r2="http://b2b.ibm.com/schema/IS_B2B_CDM/R2_2">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
通过在xslt中使用上面的代码,我可以将整个输入复制为输出,但在我的要求中,我需要映射而不是硬编码值的TransactionDateTime
<TransactionDateTime>2012-10-19T16:05:56Z</TransactionDateTime>
我需要在事务中使用此函数而不是硬编码。 下面是我的xslt代码,但它没有提供输出
<xsl:template match="r2:TransactionDateTime">
<xsl:value-of select="current-dateTime()"/>
</xsl:template>
答案 0 :(得分:3)
添加与要更改的节点匹配的另一个模板,并在其中执行更改:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:r2="http://b2b.ibm.com/schema/IS_B2B_CDM/R2_2">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="r2:DataSource">
<xsl:copy>Maximo</xsl:copy>
</xsl:template>
</xsl:stylesheet>