Написать в конце XML - PullRequest
       0

Написать в конце XML

5 голосов
/ 14 января 2011

У меня есть несколько файлов XML, в List<File>. Что я хочу, чтобы преобразовать эти XML в один XML с Xsl:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output method="xml" indent="yes"/>

<xsl:template match="testsuites">
    <xsl:call-template name="summary"/>
</xsl:template>

 <xsl:template name="summary">
           <xsl:variable name="testCount" select="sum(testsuite/@tests)"/>
         <xsl:variable name="errorCount" select="sum(testsuite/@errors)"/>
         <xsl:variable name="failureCount" select="sum(testsuite/@failures)"/>
 <xsl:variable name="timeCount" select="sum(testsuite/@time)"/>
         <xsl:variable name="successRate" select="($testCount - $failureCount - $errorCount) div $testCount"/>
          <xsl:attribute name="class">
                <xsl:choose>
                    <xsl:when test="$failureCount &gt; 0">Failure</xsl:when>
                    <xsl:when test="$errorCount &gt; 0">Error</xsl:when>
                </xsl:choose>
            </xsl:attribute>
         <Build>
          <NombreTest><xsl:value-of select="$testCount"/></NombreTest>
          <Failures><xsl:value-of select="$failureCount"/></Failures>
          <Erreurs><xsl:value-of select="$errorCount"/></Erreurs>
         <PercentSucces><xsl:call-template name="display-percent">
                    <xsl:with-param name="value" select="$successRate"/>
                </xsl:call-template></PercentSucces>
          <ExecTime><xsl:call-template name="display-time">
                   <xsl:with-param name="value" select="$timeCount"/>
                </xsl:call-template> </ExecTime>
          </Build> 
       </xsl:template>

<xsl:template match="failure">
    <xsl:call-template name="display-failures"/>
</xsl:template>

<xsl:template match="error">
    <xsl:call-template name="display-failures"/>
</xsl:template>

<xsl:template name="display-time">
    <xsl:param name="value"/>
    <xsl:value-of select="format-number($value,'0.000')"/>
</xsl:template>

<xsl:template name="display-percent">
    <xsl:param name="value"/>
    <xsl:value-of select="format-number($value,'0.00%')"/>
</xsl:template>

<xsl:template name="display-failures">
    <xsl:choose>
        <xsl:when test="not(@message)">N/A</xsl:when>
        <xsl:otherwise>
            <xsl:value-of select="@message"/>
        </xsl:otherwise>
    </xsl:choose>
 </xsl:template>

</xsl:stylesheet>

Моя проблема в том, что когда я зацикливаюсь и применяю преобразование с TransformerFactory, оно всегда стирает выходной XML. Вместо этого я хочу отредактировать вывод.

Я знаю, что могу сделать это в Java с временным XML и после слияния, но я почти уверен, что это возможно в XSL?

Спасибо за помощь

Ответы [ 2 ]

1 голос
/ 14 января 2011

Вам нужно передать все URL документа в одном внешнем параметре, и вы, как правило, будете иметь такое преобразование :

<xsl:stylesheet version="1.0"
 xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output omit-xml-declaration="yes" indent="yes"/>

 <xsl:param name="pdocNames">
  <name>doc1.xml</name>
  <name>doc2.xml</name>
  <name>doc3.xml</name>
 </xsl:param>

    <!-- you can directly use $pdocNames/name
        if the param is provided externally -->
 <xsl:variable name="vDocNames" select=
  "document('')/*/xsl:param[]@name='pdocNames']/name"/>

 <xsl:template match="/">
     <combinedDocs>
    <xsl:copy-of select="document($vDocNames)"/>
     </combinedDocs>
 </xsl:template>
</xsl:stylesheet>

Когда это преобразование применяется к любому документу XML (не используется), выполняется следующее :

  1. Получает элементы name, которые содержат в параметре $pdocNames URI документа . Эти элементы содержатся в переменной vDocNames.

  2. Создает верхний элемент для выходного документа (в данном случае с именем combinedDocs).

  3. Копирует все документы XML, URI которых содержатся в элементах name, содержащихся в переменной vDocNames . Здесь используется стандартная функция XSLT document().

Примечание :

URL-адреса всех требуемых XML-документов должны передаваться извне через параметр преобразования. Это зависит от поставщика, как передать параметр в преобразование. Вам необходимо прочитать документацию, предоставленную для вашего конкретного процессора XSLT.

0 голосов
/ 14 января 2011

Вам необходимо загрузить документы с функцией XSLT для документов (URI)

См. Также: http://www.w3schools.com/Xsl/func_document.asp

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...