我使用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>
Run Code Online (Sandbox Code Playgroud)
File2.xml
<container>
<build>
<Tests>
<Results>
<Result testName="TestOne" outcome="Passed" ></Result>
<Result testName="TestTwo" outcome="Failed" ></Result>
</Results>
</Tests>
</build>
</container>
Run Code Online (Sandbox Code Playgroud)
File3.xml
<container>
<build>
<Tests>
<Results>
<Result testName="TestOne" outcome="Failed" ></Result>
<Result testName="TestTwo" outcome="Failed" ></Result>
</Results>
</Tests>
</build>
</container>
Run Code Online (Sandbox Code Playgroud)
INDEX.XML
<?xml-stylesheet type="text/xsl" href="merge3.xsl"?>
<list>
<entry name="File1.xml" />
<entry name="File2.xml" />
<entry name="File3.xml" />
</list>
Run Code Online (Sandbox Code Playgroud)
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>
Run Code Online (Sandbox Code Playgroud)
结果产生3个Totals表.我的目的是显示一个Totals表,显示TestOne在所有XML文档中传递和失败的次数.似乎正在读取/选择每个XML文档,然后一次处理一个.我想在处理之前读入并选择所有XML文件.
你可以收集所有的Result元素来自全国各地使用类似的三个文件
<xsl:variable name="allResults"
select="(/ | document('file2.xml') | document('file3.xml'))//Result" />
Run Code Online (Sandbox Code Playgroud)
然后将谓词应用于此计算您感兴趣的元素,例如
<xsl:value-of select="
count($allResults[@testName = 'TestOne'][@outcome = 'Failed'])" />
Run Code Online (Sandbox Code Playgroud)
如果您有一个index.xml列出要组合的所有文件的main ,而不是一组固定的文件名,例如:
<list>
<entry name="File1.xml" />
<entry name="File2.xml" />
<entry name="File3.xml" />
</list>
Run Code Online (Sandbox Code Playgroud)
然后你可以使用这个索引作为样式表的主要输入,allResults变量变为:
<xsl:variable name="allResults"
select="document(/list/entry/@name)//Result" />
Run Code Online (Sandbox Code Playgroud)
将节点集传递给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>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15110 次 |
| 最近记录: |