1

我有一个 XSLT 转换,它将节点 NADR_KOD 的名称更改为 NADR_KOD2,并复制 XML 的其余部分而不做任何更改。今天我想添加另一个将属性更改为元素的转换(我在堆栈上找到了解决方案)但是一个 xslt 中的这两个转换不起作用......

出现问题是因为我无法在 SSIS 中加载“日期”属性。XML Source 始终将日期返回为空。也许你可以帮我解决这个问题?

XML的结构:

<DATA>
<ACCIDENT date="...">


 <INFO>
 <TEMP>
  <NADR_KOD>
   <NADR_KOD>Code</NADR_KOD>
  </NADR_KOD>
 </TEMP>
 </INFO>

</ACCIDENT>
</DATA>

这是我想要的:

<DATA>
<ACCIDENT>
 <date>...</date>

 <INFO>
 <TEMP>
  <NADR_KOD>
   <NADR_KOD2>Code</NADR_KOD2>
  </NADR_KOD>
 </TEMP>
 </INFO>

</ACCIDENT>
</DATA>

我有几个类似的转换。这是我做这个的方法:

  <xsl:template match="ACCIDENT">
  <!-- output a filter element -->
  <xsl:element name="ACCIDENT">
    <!-- add the name attribute, using the source name attribute value -->


   <xsl:element name="date">
     <xsl:value-of select="@date"/>
   </xsl:element>

   <!-- add the rest of attributes without change -->
   <xsl:copy-of select="node()"/>
 </xsl:element>


 </xsl:template>

 <xsl:template match="NADR_KOD/NADR_KOD">
    <NADR_KOD2>
        <xsl:apply-templates select="@*|node()"/>
    </NADR_KOD2>
 </xsl:template>

此代码不会将 NADR_KOD 更改为 NADR_KOD2。提前致谢...

4

1 回答 1

0

我认为而不是

<!-- add the rest of attributes without change -->
   <xsl:copy-of select="node()"/>

你只是想要

<!-- run the child elements through the identity transformation template for copying
     or my templates for transforming -->
<xsl:apply-templates/>

那么你可以使用

<xsl:template match="@* | node()">
  <xsl:copy>
    <xsl:apply-templates select="@* | node()"/>
  </xsl:copy>
</xsl:template>

当然还有你的

 <xsl:template match="NADR_KOD/NADR_KOD">
    <NADR_KOD2>
        <xsl:apply-templates select="@*|node()"/>
    </NADR_KOD2>
 </xsl:template>

如果要转换更多元素,则可以为它们添加模板。

于 2013-09-11T15:47:09.697 回答