使用应用模板

时间:2018-03-05 17:28:18

标签: xslt xslt-1.0

我尝试转换以下XML文件,如果后跟<AGGREGATION>节点,则删除每个<MULTIPLE>节点。

<?xml version="1.0" encoding="UTF-8"?>
    <RECORD TEMPLATE="PRODUCTS" TRACK="1">
        <FIELD NAME="PRODUCT" BASE="CT300" COUNT="2">
            <AGGREGATION DOMAIN="4" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <TOKEN TEXT="CT300" BEGIN="11379" END="11384"/>
            <AGGREGATION DOMAIN="9" />
            <AGGREGATION DOMAIN="4" />
            <AGGREGATION DOMAIN="4" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <MULTIPLE TYPE="YES" />
            <TOKEN TEXT="CT300" BEGIN="11379" END="11384"/>
        </FIELD>
    </RECORD>

通过以下xslt转换,我只能删除第一次出现的<AGGREGATION>节点:

<?xml version="1.0" encoding="UTF-8"?>                        
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:template match="@*|node()">
    <xsl:copy>
      <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>   

<xsl:template match="//RECORD[@TEMPLATE='PRODUCTS']/FIELD[@NAME='PRODUCT']/AGGREGATION[following-sibling::*[1][self::MULTIPLE]]">
    <xsl:choose>
        <xsl:when test="//RECORD[@TEMPLATE='PRODUCTS']/FIELD[@NAME='PRODUCT']/AGGREGATION[following-sibling::*[1][self::MULTIPLE]]">
        </xsl:when>
        <xsl:otherwise>
            <xsl:copy>
                <xsl:apply-templates select="@*|node()" />
            </xsl:copy>
        </xsl:otherwise>
    </xsl:choose>  
</xsl:template>

</xsl:stylesheet>

这是我收到的输出:

<?xml version="1.0" encoding="UTF-8"?>
<RECORD TEMPLATE="PRODUCTS" TRACK="1">
        <FIELD BASE="CT300" COUNT="2" NAME="PRODUCT">
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <TOKEN BEGIN="11379" END="11384" TEXT="CT300"/>
            <AGGREGATION DOMAIN="9"/>
            <AGGREGATION DOMAIN="4"/>

            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <TOKEN BEGIN="11379" END="11384" TEXT="CT300"/>
        </FIELD>
   </RECORD>

虽然所需的输出如下:

<?xml version="1.0" encoding="UTF-8"?>
<RECORD TEMPLATE="PRODUCTS" TRACK="1">
        <FIELD BASE="CT300" COUNT="2" NAME="PRODUCT">

            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <TOKEN BEGIN="11379" END="11384" TEXT="CT300"/>             
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <MULTIPLE TYPE="YES"/>
            <TOKEN BEGIN="11379" END="11384" TEXT="CT300"/>
        </FIELD>
 </RECORD>

如何实现<AGGREGATION>节点的递归删除?

3 个答案:

答案 0 :(得分:0)

只需使用此空模板和身份模板即可有条件地消除不需要的<AGGREGATION>元素:

<xsl:template match="AGGREGATION[following-sibling::*[1] = (self::MULTIPLE or self::AGGREGATION)]" />

答案 1 :(得分:0)

我认为你只需要忽略以下兄弟[[150 150 150 ..., 150 150 150] [150 173 175 ..., 97 91 89] [150 176 179 ..., 95 89 82] ..., [150 66 67 ..., 152 154 152] [150 62 59 ..., 152 152 152] [150 62 64 ..., 155 154 151]] 元素......

AGGREGATION

答案 2 :(得分:0)

我的解决方案如下:

  1. 撰写与AGGREGATION匹配的模板。
  2. 是否应该复制任何内容的决定如下:
    • 以下列第一个兄弟姐妹的名字!= AGGREGATION
    • 检查其名称是否为MULTIPLE
    • 如果是,则不执行任何操作(跳过当前的AGGREGATION元素)。
    • 如果没有,请为当前元素应用模板。
  3. 您还需要身份模板
  4. 所以整个脚本如下所示:

    <?xml version="1.0" encoding="UTF-8" ?>
    <xsl:transform version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
      <xsl:output method="xml" encoding="UTF-8" indent="yes" />
      <xsl:strip-space elements="*"/>
    
      <xsl:template match="AGGREGATION">
        <xsl:if test="not(following-sibling::*[name()!='AGGREGATION'][1]
          [name()='MULTIPLE'])">
          <AGGREGATION>
            <xsl:apply-templates select="@*|node()"/>
          </AGGREGATION>
        </xsl:if>      
      </xsl:template>
    
      <xsl:template match="@*|node()">
        <xsl:copy><xsl:apply-templates select="@*|node()"/></xsl:copy>
      </xsl:template>
    </xsl:transform>
    

    有关工作示例,请参阅http://xsltransform.net/bEJaofQ/1