使用XSLT从两个XML文件中获取数据并合并为一个?

时间:2016-11-17 20:57:57

标签: xml xslt

我尝试使用XSLT 1.0合并两个表。

我在XML中表示了两个DB表。第一个表是一组键值对:

Table1.xml

SelectedTags

第二个表包含数据行:

Table2.xml

<table>
  <row>
    <column name="key">key1</column>
    <column name="value">val1</column>
  </row>
  <row>
    <column name="key">key2</column>
    <column name="value">val2</column>
  </row>
</table>

我正在尝试使用其中一个键值对,并在每一行中添加插入为新列,以便最终得到:

的Output.xml

<table>
  <row>
    <column name="A">a1</column>
    <column name="B">b1</column>
    <column name="C">c1</column>
  </row>
  <row>
    <column name="A">a2</column>
    <column name="B">b2</column>
    <column name="C">c2</column>
  </row>
</table>

2 个答案:

答案 0 :(得分:1)

以下是该解决方案的两个主要成分:

<xsl:variable name="kvp">
  <xsl:variable name="row" select="doc('table1.xml')/table/row[1]"/>
  <column name="{$row/column[1]}">
    <xsl:value-of select="$row/column[2]"/>
  </column>
</xsl:variable>

<xsl:template match="row">
  <row>
    <xsl:copy-of select="*"/>
    <xsl:copy-of select="$kvp"/>
  </row>
</xsl:template>

答案 1 :(得分:0)

  

我想选择键为“key1”的行并创建一个新行   输出表中的列。

假设您正在处理Table2.xml文件,您可以执行以下操作:

XSLT 1.0

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

<xsl:variable name="val" select="document('Table1.xml')/table/row[column[1]='key1']/column[2]" />

<!-- identity transform -->
<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="row">
    <xsl:copy>
        <xsl:apply-templates/>
        <column name="key1">
            <xsl:value-of select="$val" />
        </column>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>