如何删除多个标签(如果存在)



我有一个xml,它可能会也可能不会产生多个系统编号。如果系统编号和外部 ID 相同,则它应仅保留一个值。

输入:

<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
   <xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
      <xsdLocal3:Contact>
         <xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
         <xsdLocal3:ListOfCIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>
         </xsdLocal3:ListOfCIFContactReference>
      </xsdLocal3:Contact>
   </xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>

输出应为:

<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
   <xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
      <xsdLocal3:Contact>
         <xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
         <xsdLocal3:ListOfCIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
         </xsdLocal3:ListOfCIFContactReference>
      </xsdLocal3:Contact>
   </xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>

如果输入为 :

<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
   <xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
      <xsdLocal3:Contact>
         <xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
         <xsdLocal3:ListOfCIFContactReference>
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
            <xsdLocal3:CIFContactReference>
               <xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
               <xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
               <xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
            </xsdLocal3:CIFContactReference>            
         </xsdLocal3:ListOfCIFContactReference>
      </xsdLocal3:Contact>
   </xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>

然后输出应显示相同。

任何投入都值得赞赏。我正在使用 XSL 1.0。

谢谢米·

Muenchian grouping,即

(只是在没有语法检查的情况下输入,但应该像这样。

  1. 为 CIFContactReference 创建一个复合索引,就像

(我曾经添加一个外来字符,比如"_",用于分隔键,当 no. 和 id 是可变长度并且合并可能会重复时。

  1. 然后在 xsdLocal3:ListOfCIFContactReference 中进行清理,

检查具有相同键的第一个节点(即.key('ref',$keyValue)[1])是否与实际节点具有相同的ID(那么这是列表中的第一个)。

在大多数情况下,这比以下兄弟姐妹快得多::xsdLocal3:CIFContactReference[...])检查;但是,如果您的列表仅由 1-2 个元素组成,则以下同级元素可能会更快一些。

相关内容

  • 没有找到相关文章