如何在使用XSL合并后处理来自多个XML文件的所有数据
发布时间:2020-12-16 07:41:17 所属栏目:百科 来源:网络整理
导读:我使用XSL读取三个相同的 XML文档,除了它们的属性具有不同的值(可能我会阅读许多XML文件).我想计算“results”属性的值为“Passed”或“Failed”的次数为“testName”属性=“TestOne”的元素的次数.我使用以下方法实现此目的: File1.xml container build Te
我使用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文档中传递和失败的次数.
您可以使用类似的东西从三个文档中收集所有结果元素
<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" /> 将节点集传递给文档函数时,它依次获取每个节点的字符串值,并将其视为要加载的文件的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> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |