2014-01-08 122 views
0

我的Xml具有以下数据。 我需要类型,标题包含在标题“步”和编辑代码步数如何使用XSLT调用XML元素

<?xml version="1.0" encoding="ISO-8859-1"?> 

<Testlog> 
     <Event Timestamp="27-Dec-2012 04:25:12.247 PM" Type="Script End" Headline="Script end [DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003]" Result="WARNING"> 
     <Property script_name="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003"/> 
     <Property script_id="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003.java"/> 
    </Event> 

    <Event Timestamp="27-Dec-2012 04:25:10.747 PM" Type="Export Event" Headline="getProperty on the List ABC: Trace Facility" Result="PASS"> 
     <Property line_number="434"/> 
     <Property script_name="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003"/> 
    </Event> 

<Event Timestamp="27-Dec-2012 04:16:33.226 PM" Type="General" Headline="_FRMWK.SystemLibrary.Sys_TmxProcesses logStepBegin: Step: 2; Action: node; Narrative: Node: &apos;DseBalanceInquiry_FC.RST_ACU_DEF(T)&apos; &apos;Use ACU to Import the default ACU settings xml file. When importing, all the checkboxes are checked in the Application list. i.e. Perform the RestoreAcuDefaults keyword &apos;; TestName: DseBalanceInquiry_FC_Test_003" Result="INFORMATION"> 
     <Property script_name="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003"/> 
     <Property line_number="61"/> 
     <Property script_id="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003.java"/> 
    </Event> 
    <Event Timestamp="27-Dec-2012 04:16:33.335 PM" Type="General" Headline="_FRMWK.SystemLibrary.Sys_TmxProcesses logStepBegin: Step: 2.001; Action: ImportACU; Narrative:    Import ACU settings based on &apos;&apos; ; TestName: DseBalanceInquiry_FC_Test_003" Result="INFORMATION"> 
     <Property script_name="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003"/> 
     <Property line_number="64"/> 
     <Property script_id="DSE.DSEBalanceInquiry_FC.DseBalanceInquiry_FC_Test_003.java"/> 
    </Event> 

</Testlog> 

。这给了我的头条列表,其中有步骤,如果我想要在单独的行中获得步骤号码,我该如何实现它?

 <?xml version="1.0" encoding="ISO-8859-1"?> 

    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 

    <xsl:template match="/"> 
    <html> 
     <body> 
    <h2>Report</h2> 
    <table border="1"> 
    <tr bgcolor="#9acd32"> 
    <th style="text-align:left">Title</th> 
    <th style="text-align:left">Artist</th> 
    <th style="text-align:left">Step</th> 
    <th style="text-align:left">Headline</th> 
    </tr> 

    <xsl:for-each select="Testlog/Event[contains(@Headline, 'Step:')]"> 
    <tr> 
    <td><xsl:value-of select="@Type"/></td> 
    <td><xsl:value-of select="@Result"/></td> 
    <td><xsl:value-of select="@Step"/></td> 
    <td><xsl:value-of select="@Headline"/></td> 
    </tr> 
    </xsl:for-each> 
</table> 
+0

你能澄清你想要添加到结果究竟是什么?你已经*有*类型和标题,以及结果。 –

+0

我无法提供正确的数据。在标题中,标题中有“STEP”,我需要这些细节来显示 – sagar

回答

0

如果你的意思是你要添加的头条事件包含“步骤:”该报告作为附加表行,然后替换此行:

<xsl:for-each select="Testlog/Event[@Result='WARNING']"> 

有:

<xsl:for-each select="Testlog/Event[@Result='WARNING' or contains(@Headline, 'Step:')]"> 

如果没有,请再澄清一些。


一个问题,如果我想在单独的行步数, 我是如何实现的呢? -

我想你的意思是单独的列,而不是行?如果是这样,另一个<td>元素添加到表(for-each循环内):

<td><xsl:value-of select="substring-before(substring-after(@Headline, 'Step:'), ';')"/></td> 

然后相应<th>元素添加到上面的表头。

+0

雅得到它。谢谢你的回答和耐心:) – sagar

+0

迈克尔我还有一个问题,如果我想要在单独的行中获得步骤编号,我该如何实现它? – sagar