组节点并删除重复项

时间:2015-06-30 21:33:27

标签: xml xslt xslt-1.0

输入:

<?xml version="1.0" encoding="UTF-8"?>
<json:object xmlns:json="http://www.ibm.com/xmlns/prod/2009/jsonx">
<json:object name="items">
    <itemConfig>
        <itemId>8955444</itemId>
        <json:number name="Price">17.99</json:number>
        <json:string name="itemId">8955444</json:string>
        <json:number name="upcNum">54654654546</json:number>
        <json:number name="freeShipFlag">1</json:number>
        <json:number name="Cartavailable">0</json:number>
        <json:number name="OnlineOnly">0</json:number>
        <json:number name="salePrice">9.39</json:number>
        <json:string name="onlinePurchDate">20150624</json:string>
        <json:string name="itemName">Conditioner</json:string>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>5646554</itemId>
        <json:number name="itemstock">179</json:number>
        <json:string name="wt">0.49 LBS</json:string>
        <json:number name="Price">3.39</json:number>
        <json:string name="itemId">5646554</json:string>
        <json:number name="upcNum">5646554892521</json:number>
        <json:string name="onlinePurchDate">20150624</json:string>
        <json:string name="itemName">oil</json:string>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>8955444</itemId>
        <json:number name="itemstock">419</json:number>
        <json:string name="wt">0.79 LBS</json:string>
        <json:string name="unitSalePrice">NA</json:string>
        <json:number name="onlineqty">0</json:number>
        <json:string name="size">6oz</json:string>
        <json:string name="category">beauty</json:string>
        <json:string name="itemId">8955444</json:string>
        <json:number name="onlineStock">1</json:number>
        <json:number name="shipsaveFlag">1</json:number>
        <json:number name="onsale">0</json:number>
        <json:number name="upcNum">54654654546</json:number>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>905678911</itemId>
        <json:number name="itemstock">157</json:number>
        <json:string name="wt">0.23 LBS</json:string>
        <json:string name="unitSalePrice">NA</json:string>
        <json:number name="onlineqty">0</json:number>
        <json:string name="title">Cleanser</json:string>
        <json:number name="Price">6.49</json:number>
        <json:string name="itemId">908911</json:string>
        <json:number name="upcNum">88941105671610</json:number>
        <json:number name="freeShipFlag">1</json:number>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>8955444</itemId>
        <json:string name="itemId">8955444</json:string>
        <json:string name="storePurchDate">20150115</json:string>
        <json:number name="storePurchqty">1</json:number>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>1410743567</itemId>
        <json:string name="itemId">1410743567</json:string>
        <json:string name="storePurchDate">20141226</json:string>
        <json:number name="storePurchqty">8</json:number>
    </itemConfig>
</json:object>
</json:object>

我有这个xml,我需要根据itemId将它分组到输出。一旦我们对两个节点进行分组,可能会有重复,我们需要删除它们。如何用muenchian方法写这个。

尝试了以下但是没有改变任何东西

XSLT:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:json="http://www.ibm.com/xmlns/prod/2009/jsonx" extension-element-prefixes="xsi" exclude-result-prefixes="xsi json">
<xsl:output method="xml" indent="yes"/>
<xsl:key name="items-by-id" match="itemConfig" use="itemId"/>
<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>
<xsl:template match="json:object[@name = 'items']">
    <xsl:copy>
        <xsl:apply-templates select="itemConfig[generate-id() = generate-id(key('items-by-id', itemId)[1])]" mode="group"/>
    </xsl:copy>
</xsl:template>
<xsl:template match="itemConfig" mode="group">
    <xsl:copy>
        <xsl:copy-of select="itemId"/>
        <xsl:apply-templates select="key('items-by-id', itemId)"/>
    </xsl:copy>
</xsl:template>
<xsl:template match="*[not(descendant::text())]"/>
</xsl:stylesheet>

输出:

<?xml version="1.0" encoding="UTF-8"?>
<json:object xmlns:json="http://www.ibm.com/xmlns/prod/2009/jsonx">
<json:object name="items">
    <itemConfig>
        <itemId>8955444</itemId>
        <json:number name="Price">17.99</json:number>
        <json:string name="itemId">8955444</json:string>
        <json:number name="upcNum">54654654546</json:number>
        <json:number name="freeShipFlag">1</json:number>
        <json:number name="Cartavailable">0</json:number>
        <json:number name="OnlineOnly">0</json:number>
        <json:number name="salePrice">9.39</json:number>
        <json:string name="onlinePurchDate">20150624</json:string>
        <json:string name="itemName">Conditioner</json:string>
        <json:number name="itemstock">419</json:number>
        <json:string name="wt">0.79 LBS</json:string>
        <json:string name="unitSalePrice">NA</json:string>
        <json:number name="onlineqty">0</json:number>
        <json:string name="size">6oz</json:string>
        <json:string name="category">beauty</json:string>
        <json:number name="onlineStock">1</json:number>
        <json:number name="shipsaveFlag">1</json:number>
        <json:number name="onsale">0</json:number>
        <json:string name="storePurchDate">20150115</json:string>
        <json:number name="storePurchqty">1</json:number>             
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>5646554</itemId>
        <json:number name="itemstock">179</json:number>
        <json:string name="wt">0.49 LBS</json:string>
        <json:number name="Price">3.39</json:number>
        <json:string name="itemId">5646554</json:string>
        <json:number name="upcNum">5646554892521</json:number>
        <json:string name="onlinePurchDate">20150624</json:string>
        <json:string name="itemName">oil</json:string>
        <json:string name="storePurchDate">20141226</json:string>
        <json:number name="storePurchqty">8</json:number>        
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>905678911</itemId>
        <json:number name="itemstock">157</json:number>
        <json:string name="wt">0.23 LBS</json:string>
        <json:string name="unitSalePrice">NA</json:string>
        <json:number name="onlineqty">0</json:number>
        <json:string name="title">Cleanser</json:string>
        <json:number name="Price">6.49</json:number>
        <json:string name="itemId">908911</json:string>
        <json:number name="upcNum">88941105671610</json:number>
        <json:number name="freeShipFlag">1</json:number>
    </itemConfig>
</json:object>
<json:object name="items">
    <itemConfig>
        <itemId>1410743567</itemId>
        <json:string name="itemId">1410743567</json:string>
        <json:string name="storePurchDate">20141226</json:string>
        <json:number name="storePurchqty">8</json:number>
    </itemConfig>
</json:object>    
</json:object>

如何实现这一目标?

1 个答案:

答案 0 :(得分:1)

  

一旦我们将两个节点分组,可能会有重复,这是我们需要的   删除。

为了对items个节点进行分组,删除每个组中的重复项,您必须两次应用Muenchian分组:

XSLT 1.0

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

<xsl:key name="items-by-id" match="itemConfig" use="itemId"/>
<xsl:key name="item-by-name" match="itemConfig/*" use="concat(../itemId, '|', @name)"/>

<xsl:template match="/json:object">
    <xsl:copy>
        <!-- for each group --> 
        <xsl:for-each select="json:object/itemConfig[count(. | key('items-by-id', itemId)[1]) = 1]">
            <json:object name="items">
                <itemConfig>
                    <!-- get distinct items in this group -->   
                    <xsl:copy-of select="key('items-by-id', itemId)/*[count(. | key('item-by-name', concat(../itemId, '|', @name))[1]) = 1]"/>
                </itemConfig>
            </json:object>
        </xsl:for-each>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>

测试输入

 <json:object xmlns:json="http://www.ibm.com/xmlns/prod/2009/jsonx">
    <json:object name="items">
        <itemConfig>
            <itemId>123</itemId>
            <json:number name="Price">17.99</json:number>
            <json:string name="itemId">123</json:string>
            <json:number name="upcNum">54654654546</json:number>
            <json:number name="salePrice">9.39</json:number>
        </itemConfig>
    </json:object>
    <json:object name="items">
        <itemConfig>
            <itemId>456</itemId>
            <json:number name="Price">3.39</json:number>
            <json:number name="upcNum">456892521</json:number>
            <json:string name="itemName">oil</json:string>
        </itemConfig>
    </json:object>
    <json:object name="items">
        <itemConfig>
            <itemId>123</itemId>
            <json:string name="itemId">123</json:string>
            <json:number name="onlineStock">1</json:number>
            <json:number name="upcNum">54654654546</json:number>
        </itemConfig>
    </json:object>
    <json:object name="items">
        <itemConfig>
            <itemId>456</itemId>
            <json:number name="upcNum">456892521</json:number>
            <json:string name="category">beauty</json:string>
        </itemConfig>
    </json:object>
    <json:object name="items">
        <itemConfig>
            <itemId>123</itemId>
            <json:string name="itemId">123</json:string>
            <json:string name="storePurchDate">20150115</json:string>
        </itemConfig>
    </json:object>
</json:object>

<强>结果

<?xml version="1.0" encoding="utf-8"?>
<json:object xmlns:json="http://www.ibm.com/xmlns/prod/2009/jsonx">
   <json:object name="items">
      <itemConfig>
         <itemId>123</itemId>
         <json:number name="Price">17.99</json:number>
         <json:string name="itemId">123</json:string>
         <json:number name="upcNum">54654654546</json:number>
         <json:number name="salePrice">9.39</json:number>
         <json:number name="onlineStock">1</json:number>
         <json:string name="storePurchDate">20150115</json:string>
      </itemConfig>
   </json:object>
   <json:object name="items">
      <itemConfig>
         <itemId>456</itemId>
         <json:number name="Price">3.39</json:number>
         <json:number name="upcNum">456892521</json:number>
         <json:string name="itemName">oil</json:string>
         <json:string name="category">beauty</json:string>
      </itemConfig>
   </json:object>
</json:object>

请注意,这假定<itemId>是其组中唯一没有name属性的人。