Używam XSL do odczytu w trzech dokumentach XML, które są identyczne, z wyjątkiem ich atrybutów mają różne wartości (potencjalnie będę czytać wiele plików XML). Chcę policzyć liczbę razy, gdy atrybut "wynikowy" ma wartość "Przekazywane" lub "Nieudane" dla elementu, którego atrybut "testName" = "TestOne". Ja to osiągnąć stosując następujący:Jak przetwarzać wszystkie dane z wielu plików XML po scaleniu przy użyciu XSL
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>
Wynik produkuje 3 sumy tabele. Moim zamiarem jest wyświetlenie jednej tabeli Sumy wyświetlającej ile razy testOne przeszedł i nie powiodło się we wszystkich dokumentach XML. Wygląda na to, że każdy dokument XML jest czytany/zaznaczany, a następnie przetwarzany pojedynczo. Chciałbym przeczytać i wybrać wszystkie pliki XML przed ich przetworzeniem.
Odmianą pierwotnego pytania wykorzystuje plik o nazwie „index.xml” zawierający odnośniki do wszystkich plików XML do procesu (może być setki) z modyfikacją do merge2.xsl.Jak osiągnąć zamierzony rezultat dzięki tej nowej wariacji? – user2734805
@ user2734805 jest to w rzeczywistości prostsze niż w przypadku stałych nazw plików - zobacz moją edycję. –
Ian - Twój przykład zadziałał dla mnie. Pojęcie "zestawu węzłów" było tym, czego mi brakowało. Dziękuję Ci. – user2734805