2014-01-08 119 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