объединить 2 xml файла с xslt - PullRequest
       1

объединить 2 xml файла с xslt

0 голосов
/ 20 декабря 2018

У меня есть два XML-файла Person1 и Person2, и я хочу объединить их в один XML-файл с помощью xslt. Я новичок в xslt, поэтому любая помощь будет полезна: первый файл Person1:

<personnes>
  <personne>
    <name>aaa</name>
    <age>10</age>
    <adress>aaaaaa</adress>
  </personne>

  <personne>
    <name>bbb</name>
    <age>10</age>
    <adress>aaaaaa</adress>
  </personne>

  <personne>
    <name>ccc</name>
    <age>20</age>
    <adress>cccccc</adress>
  </personne>

  <personne>
    <name>ddd</name>
    <age>10</age>
    <adress>cccccc</adress>
  </personne>


</personnes>

Второйфайл people2:

<personnes>
  <personne>

    <id>1111</id>
    <quantity>1100</quantity>
  </personne>

  <personne>

     <id>2222</id>
     <quantity>2200</quantity>
  </personne>

  <personne>

    <id>3333</id>
    <quantity>3300</quantity>
  </personne>

  <personne>

    <id>4444</id>
    <quantity>4400</quantity>
  </personne>

  <personne>

    <id>5555</id>
    <quantity>5500</quantity>
  </personne>
</personnes>

, и я хочу получить результат в новом XML-файле, как показано ниже:

<personnes>
  <personne>
    <id>1111</id>
    <name>aaa</name>
    <quantity>1100</quantity>
    <age>10</age>
    <adress>aaaaaa</adress>
  </personne>

  <personne>
    <id>2222</id>
    <name>bbb</name>
    <quantity>2200</quantity>
    <age>10</age>
    <adress>aaaaaa</adress>
  </personne>

  <personne>
    <id>3333</id>
    <name>ccc</name>
    <quantity>3300</quantity>
    <age>20</age>
    <adress>cccccc</adress>
  </personne>

  <personne>
    <id>4444</id>
    <name>ddd</name>
    <quantity>4400</quantity>
    <age>10</age>
    <adress>cccccc</adress>
  </personne>


</personnes>

Я хочу взять идентификатор и количество из файла: people2 и поместить их вXML-файл: people1, один за другим, означающий первый с первым, второй со вторым и т. д. *

Ответы [ 2 ]

0 голосов
/ 21 декабря 2018
 <xsl:variable name="doc" select="document('person2.xml')"/>
    <xsl:template match="@*|node()">
        <xsl:copy>
            <xsl:apply-templates select="@*|node()"/>
        </xsl:copy>
    </xsl:template>

    <xsl:template match="personnes">
        <xsl:copy>
            <xsl:for-each select="personne">
                <xsl:variable name="pos" select="position()"/>
                <xsl:copy>
                    <xsl:if test=".[$pos=$doc/personnes/personne/position()]">
                    <xsl:copy-of select="$doc/personnes/personne[position() =$pos]/id"/>
                </xsl:if>
                <xsl:if test="child::name">
                    <name>
                        <xsl:value-of select="name"/>
                    </name>
                </xsl:if>
                <xsl:if test=".[$pos=$doc/personnes/personne/position()]">
                    <xsl:copy-of select="$doc/personnes/personne[position() =$pos]/quantity"/>
                </xsl:if>
                <xsl:if test="child::age">
                    <age>
                        <xsl:value-of select="age"/>
                    </age>
                </xsl:if>
                <xsl:if test="child::adress">
                    <adress>
                        <xsl:value-of select="adress"/>
                    </adress>
                </xsl:if>
                </xsl:copy>

            </xsl:for-each>
        </xsl:copy>
    </xsl:template> 
You may also try this
0 голосов
/ 21 декабря 2018

Вот XSL-файл, который должен выполнить то, что вы ищете из слияния:

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

<!-- load the merge file -->
<xsl:variable name="personne2"
  select="document('file2.xml')"/>

<xsl:template match="/">

<personnes>
<xsl:for-each select="personnes/personne">


<xsl:variable name="elementposition" select="count(preceding-sibling::*)+1"/>

   <!-- copy the child nodes -->
   <personne>

   <xsl:copy-of select="$personne2/personnes//personne[position() = $elementposition]/id"/>
   <xsl:copy-of select="child::name"/>
   <xsl:copy-of select="$personne2/personnes//personne[position() = $elementposition]/quantity"/>
   <xsl:copy-of select="child::age"/>
   <xsl:copy-of select="child::address"/>

   </personne>
</xsl:for-each>
</personnes>

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