1

我需要转换一个 XML,其中转换规则应仅适用于某些元素,其余部分应按原样复制。下面是源和预期的 xml 块。

<Object class="Item" version="1.0" distName="A-1/B-1/Item-0">
     <p name="sDate">2013-02-11T00:00:00+02:00:00</p>
     <p name="present">1</p>
     <p name="stopD">2013-02-21T00:00:00+02:00:00</p>
     <p name="id">CPU</p>
</Object>
<Object class="Period" version="1.0" distName="A-1/B-1/Item-0/Period-0">
     <p name="sHour">0</p>
     <p name="sMinute">0</p>
     <p name="interval">1</p>
     <p name="day">0</p>
</Object>

<Object class="Items" distName="A-1/B-1/Items-0">
<p name="IsPresent">1</p>
<p name="StartDate">08-11-2012</p>
<p name="StopDate">29-11-2012</p>
<list name="TimePeriod">
    <item>
        <p name="id">1</p>
        <p name="StartTime">00:00</p>
        <p name="day">0</p>
        <p name="interval">15</p>
    </item>
</list>
<list name="TypeRef">
    <p>Diameter</p>
</list>

1. 以上 Object 元素应与另一个基于具有父子层次结构的 distName 的 Object 元素组合。例如:A-1/B-1/Item-0A-1/B-1/Item-0/Period-0

  1. 映射如下:
    • sDate 到 StartDate
    • 呈现给 IsPresent
    • stopD 到 StopDate
    • id 到 TypeRef 列表
    • 另一个源节点应映射到时间段列表

谁能帮我解决这个问题??

4

1 回答 1

1

您预期结果中的某些项目似乎与输入不匹配,但也许这会帮助您从 A 点到 B 点。我没有在这里进行日期转换,我不知道您的源代码中的 TypeRef 是什么。

      <xsl:template match="Object[@class='Item']">
            <xsl:variable name="mainobj" select="."/>
            <xsl:variable name="distName" select="@distName"/>
            <Object class="Items" distName="{$distName}">
                <p name="IsPresent">
                    <xsl:value-of select="p[@name='present']"/>
                </p>
                <p name="StartDate">
                    <xsl:value-of select="p[@name='sDate']"/>
                </p>
                <p name="StopDate">
                    <xsl:value-of select="p[@name='stopD']"/>
                </p>
                <xsl:variable name="objperiod" select="//Object[starts-with(@distName,$distName)][not(.=$mainobj)]"/>
                <xsl:for-each select="$objperiod">
                <list name="TimePeriod">
                    <item>
                        <p name="id">
                            <xsl:value-of select="p[@name='id']"/>
                        </p>

                        <p name="StartTime">
                            <xsl:value-of select="concat(format-number($objperiod/p[@name='sHour'],'00'),':',format-number($objperiod/p[@name='sMinute'],'00'))"/>
                        </p>
                        <p name="day">
                            <xsl:value-of select="$objperiod/p[@name='day']"/>
                        </p>
                        <p name="interval">
                            <xsl:value-of select="$objperiod/p[@name='interval']"/>
                        </p>
                    </item>
                </list>
                </xsl:for-each>
            </Object>
        </xsl:template>  

这会产生以下结果:

   <Object class="Items" distName="A-1/B-1/Item-0">
       <p name="IsPresent">1</p>
       <p name="StartDate">2013-02-11T00:00:00+02:00:00</p>
       <p name="StopDate">2013-02-21T00:00:00+02:00:00</p>
       <list name="TimePeriod">
           <item>
               <p name="id">CPU</p>
               <p name="StartTime">00:00</p>
               <p name="day">0</p>
               <p name="interval">1</p>
           </item>
       </list>
       <list name="TimePeriod">
           <item>
               <p name="id"/>
               <p name="StartTime">00:00</p>
               <p name="day">0</p>
               <p name="interval">1</p>
           </item>
       </list>
       <list name="TimePeriod">
           <item>
               <p name="id"/>
               <p name="StartTime">00:00</p>
               <p name="day">0</p>
               <p name="interval">1</p>
           </item>
       </list>
   </Object>
于 2013-06-20T23:24:44.383 回答