首页 > 解决方案 > XSLT 循环返回相同的值

问题描述

XSLT 的新手,我想展平我的 XML 文件以便(稍后)摄取到 SQL 中。目前我在遍历 XML 文档时遇到了麻烦。目前它会获取标签的数量,但会返回相同的值。此外,当循环中存在循环时,似乎根本没有获取值的问题。

XML:

<?xml version="1.0"?>
<Example>
  <Num>12</Num>
  <Num>13</Num>
  <Num>14</Num>
  <Num>15</Num>
  <Num>16</Num>
  <New>N</New>
  <Age>118</Age>
  <Name>
    <PrimNam>
      <Surnm>SAM</Surnm>
      <FstNm>SAM</FstNm>
      <SecNm>SAM</SecNm>
    </PrimNam>
    <Alias>
      <Id>12</Id>
      <DOB>01/01/1900</DOB>
      <AliasNam>
        <Surnm>SAM</Surnm>
        <FstNm>SAMUEL</FstNm>
      </AliasNam>
      <AliasDate>28/12/2018</AliasDate>
    </Alias>
  </Name>
</Example>

这是我的 XSLT 目前的样子

<xsl:for-each select="Example/Num">
    <Num><xsl:value-of select="../Num"/></Num>
</xsl:for-each>

    <New><xsl:value-of select="Example/New"/></New>
    <Age><xsl:value-of select="Example/Age"/></Age>

    <xsl:for-each select="Example/Name/PrimNam">
        <Surnm><xsl:value-of select="../../Surnm"/></Surnm>
        <FstNm><xsl:value-of select="../../FstNm"/></FstNm>
        <SecNm><xsl:value-of select="../../SecNm"/></SecNm>
    </xsl:for-each>
    <xsl:for-each select="Example/Name/Alias">
        <Id><xsl:value-of select="../../Id"/></Id>
        <DOB><xsl:value-of select="../../DOB"/></DOB>
            <xsl:for-each select="Example/Name/Alias/AliasNam">
                <Surnm><xsl:value-of select="../../../Surnm"/></Surnm>
                <FstNm><xsl:value-of select="../../../FstNm"/></FstNm>
            </xsl:for-each>
        <AliasDate><xsl:value-of select="../../AliasDate"/></AliasDate>
    </xsl:for-each>

结果输出如下所示

<Num>12</Num>
<Num>12</Num>
<Num>12</Num>
<Num>12</Num>
<Num>12</Num>
<New>N</NewCon>
<Age>118</Age>
<Surnm></Surnm>
<FstNm></FstNm>
<SecNm></SecNm>
<Id></Id>
<DOB></DOB>
<AliasDate></AliasDate>

标签: xmlxslt

解决方案


您似乎想要展平您的 XML。
一种可能性是以下 XSLT-1.0 模板:

<xsl:template match="Example/Num | Example/New | Example/Age | Example/Name/PrimNam/* | Example/Name/Alias/Id | Example/Name/Alias/DOB | Example/Name/Alias/AliasNam/* | Example/Name/Alias/AliasDate">
  <xsl:copy>
    <xsl:apply-templates select="@*|node()"/>
  </xsl:copy>
</xsl:template>

输出是:

<Num>12</Num>
<Num>13</Num>
<Num>14</Num>
<Num>15</Num>
<Num>16</Num>
<New>N</New>
<Age>118</Age>
<Surnm>SAM1</Surnm>
<FstNm>SAM2</FstNm>
<SecNm>SAM3</SecNm>
<Id>12</Id>
<DOB>01/01/1900</DOB>
<Surnm>SAM</Surnm>
<FstNm>SAMUEL</FstNm>
<AliasDate>28/12/2018</AliasDate>

这是输入 XML 的扁平化版本。


推荐阅读