[英]How to process all data from multiple XML files after merging using XSL
我使用XSL讀取三個相同的XML文檔,除了它們的屬性具有不同的值(可能我會閱讀許多XML文件)。 我想計算“results”屬性的值為“Passed”或“Failed”的次數為“testName”屬性=“TestOne”的元素的次數。 我使用以下方法實現此目的:
File1.xml
<container>
<build>
<Tests>
<Results>
<Result testName="TestOne" outcome="Passed" ></Result>
<Result testName="TestTwo" outcome="Passed" ></Result>
</Results>
</Tests>
</build>
</container>
File2.xml
<container>
<build>
<Tests>
<Results>
<Result testName="TestOne" outcome="Passed" ></Result>
<Result testName="TestTwo" outcome="Failed" ></Result>
</Results>
</Tests>
</build>
</container>
File3.xml
<container>
<build>
<Tests>
<Results>
<Result testName="TestOne" outcome="Failed" ></Result>
<Result testName="TestTwo" outcome="Failed" ></Result>
</Results>
</Tests>
</build>
</container>
INDEX.XML
<?xml-stylesheet type="text/xsl" href="merge3.xsl"?>
<list>
<entry name="File1.xml" />
<entry name="File2.xml" />
<entry name="File3.xml" />
</list>
Merge2.xsl
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html"/>
<xsl:template match="/">
<xsl:for-each select="/list/entry">
<xsl:apply-templates select="document(@name)/container/build/*[local-name()='Tests']" />
</xsl:for-each>
</xsl:template>
<xsl:template match="*[local-name()='Results']">
<xsl:variable name="name" select="'TestOne'" />
<xsl:variable name="totalPassed" select="*[local-name()='Result'][@testName = 'TestOne'][@outcome = 'Passed']" />
<xsl:variable name="totalFailed" select="*[local-name()='Result'][@testName = 'TestOne'][@outcome = 'Failed']" />
<h2>Totals</h2>
<table border="1" cellSpacing="0" cellPadding="5" >
<tr bgcolor="#9acd32">
<th>Test Name</th>
<th>Total Passed</th>
<th>Total Failed</th>
</tr>
<tr>
<td><xsl:value-of select="$name"/></td>
<td><xsl:value-of select="count($totalPassed)"/></td>
<td><xsl:value-of select="count($totalFailed)"/></td>
</tr>
</table>
</xsl:template>
</xsl:stylesheet>
結果產生3個Totals表。 我的目的是顯示一個Totals表,顯示TestOne在所有XML文檔中傳遞和失敗的次數。 似乎正在讀取/選擇每個XML文檔,然后一次處理一個。 我想在處理之前讀入並選擇所有XML文件。
您可以使用類似的東西從三個文檔中收集所有 Result
元素
<xsl:variable name="allResults"
select="(/ | document('file2.xml') | document('file3.xml'))//Result" />
然后將謂詞應用於此計算您感興趣的元素,例如
<xsl:value-of select="
count($allResults[@testName = 'TestOne'][@outcome = 'Failed'])" />
如果您有一個列出要組合的所有文件的主index.xml
,而不是一組固定的文件名,例如:
<list>
<entry name="File1.xml" />
<entry name="File2.xml" />
<entry name="File3.xml" />
</list>
那么你可以使用這個索引作為樣式表的主要輸入,並且allResults
變量變為:
<xsl:variable name="allResults"
select="document(/list/entry/@name)//Result" />
將節點集傳遞給document
函數時,它依次獲取每個節點的字符串值,並將其視為要加載的文件的URI,並返回生成的文檔根節點集 。
這是一個完整的例子
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html"/>
<xsl:variable name="allResults"
select="document(/list/entry/@name)//Result" />
<xsl:template match="/">
<xsl:variable name="name" select="'TestOne'" />
<h2>Totals</h2>
<table border="1" cellSpacing="0" cellPadding="5" >
<tr bgcolor="#9acd32">
<th>Test Name</th>
<th>Total Passed</th>
<th>Total Failed</th>
</tr>
<tr>
<td><xsl:value-of select="$name"/></td>
<td><xsl:value-of select="count($allResults[@testName = $name]
[@outcome = 'Passed'])"/></td>
<td><xsl:value-of select="count($allResults[@testName = $name]
[@outcome = 'Failed'])"/></td>
</tr>
</table>
</xsl:template>
</xsl:stylesheet>
這與上面幾乎相同,但沒有變量。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html"/>
<xsl:template match="/">
<h2>Totals</h2>
<table border="1" cellSpacing="0" cellPadding="5" >
<tr bgcolor="#9acd32">
<th>Test Name</th>
<th>Total Passed</th>
<th>Total Failed</th>
</tr>
<xsl:for-each select="/list/entry">
<tr>
<td><xsl:value-of select="@name"/></td>
<td><xsl:value-of select="count(document(@name)/container/build/Tests/Results/Result[@outcome eq 'Passed'])"/></td>
<td><xsl:value-of select="count(document(@name)/container/build/Tests/Results/Result[@outcome eq 'Failed'])"/></td>
</tr>
</xsl:for-each>
</table>
</xsl:template>
</xsl:stylesheet>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.