***This is my input xml coming from source.***
<?xml version="1.0" encoding="UTF-8" ?>
<exampleElement xmlns="http://www.example.org">
<element1>
<Id>123</Id>
<Name>Imag</Name>
<Status>active</Status>
<EndDate/>
</element1>
<element1>
<Id>888</Id>
<Name>Preci</Name>
<Status>active</Status>
<EndDate/>
</element1>
<element1>
<Id>123</Id>
<Name>Imag</Name>
<Status>terminated</Status>
<EndDate>2016-12-10</EndDate>
</element1>
<element1>
<Id>143</Id>
<Name>kilok</Name>
<Status>terminated</Status>
<EndDate>2016-11-10</EndDate>
</element1>
</exampleElement>
在上面的输入数据中,两组重复了不同的值。id = 123元素节点具有两个具有端向值的记录,并且具有端向。
**I want out put in this below format where one record set
from duplicates with EndDate tag empty.**
<?xml version = '1.0' encoding = 'UTF-8'?>
<ns1:exampleElement xmlns:ns1="http://www.example.org">
<ns1:element1>
<ns1:Id>888</ns1:Id>
<ns1:Name>Preci</ns1:Name>
<ns1:Status>active</ns1:Status>
<ns1:EndDate/>
</ns1:element1>
<ns1:element1>
<ns1:Id>123</ns1:Id>
<ns1:Name>Imag</ns1:Name>
<ns1:Status>active</ns1:Status>
<ns1:EndDate/>
</ns1:element1>
<ns1:element1>
<ns1:Id>143</ns1:Id>
<ns1:Name>Kilok</ns1:Name>
<ns1:Status>terminated</ns1:Status>
<ns1:EndDate>2016-11-10</ns1:EndDate>
</ns1:element1>
</ns1:exampleElement>
请在我的XSLT下找到将提供唯一记录的XSLT,但我想根据价值获取唯一的记录。
<xsl:template match="/">
<ns1:exampleElement>
<xsl:for-each select="/ns1:exampleElement/ns1:element1[not(ns1:Id=following::ns1:Id)]">
<ns1:element1>
<ns1:Id>
<xsl:value-of select="./ns1:Id"/>
</ns1:Id>
<ns1:Name>
<xsl:value-of select="./ns1:Name"/>
</ns1:Name>
<ns1:Status>
<xsl:value-of select="./ns1:Status"/>
</ns1:Status>
<ns1:EndDate>
<xsl:value-of select="./ns1:EndDate"/>
</ns1:EndDate>
</ns1:element1>
</xsl:for-each>
</ns1:exampleElement>
因为来自源系统将在第一组中接收用户活动记录,并在第二组中终止记录,但我们只需要将活动记录转发到目标系统。请为此提供帮助。
您在评论中为您提供了指向穆奇人分组的文章的链接,这解释了采取的方法。它涉及首先定义要匹配要分组的元素的键(其中ns1
是绑定到名称空间URI的名称空间前缀)
<xsl:key name="elements" match="ns1:element1" use="ns1:Id" />
然后,要获取不同的
(或者是Id
的每个可能值的第一次出现元素),您将做到这一点...
<xsl:for-each select="ns1:element1[generate-id() = generate-id(key('elements', ns1:Id)[1])]" />
要访问组中的所有元素,请执行此操作。
<xsl:for-each select="key('elements', ns1:Id)">
尝试此XSLT
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ns1="http://www.example.org">
<xsl:key name="elements" match="ns1:element1" use="ns1:Id" />
<xsl:output method="xml" indent="yes" />
<xsl:template match="/">
<xsl:copy>
<xsl:for-each select="*/ns1:element1[generate-id() = generate-id(key('elements', ns1:Id)[1])]">
<xsl:for-each select="key('elements', ns1:Id)">
<xsl:sort select="ns1:EndDate" />
<xsl:if test="position() = 1">
<xsl:apply-templates select="." />
</xsl:if>
</xsl:for-each>
</xsl:for-each>
</xsl:copy>
</xsl:template>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
如果您真的想使用ns1:
前缀输出XML(尽管确实不应该有所作为)
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ns1="http://www.example.org">
<xsl:key name="elements" match="ns1:element1" use="ns1:Id" />
<xsl:output method="xml" indent="yes" />
<xsl:template match="/">
<ns1:exampleElement>
<xsl:for-each select="*/ns1:element1[generate-id() = generate-id(key('elements', ns1:Id)[1])]">
<xsl:for-each select="key('elements', ns1:Id)">
<xsl:sort select="ns1:EndDate" />
<xsl:if test="position() = 1">
<xsl:apply-templates select="." />
</xsl:if>
</xsl:for-each>
</xsl:for-each>
</ns1:exampleElement>
</xsl:template>
<xsl:template match="*" priority="2">
<xsl:element name="ns1:{local-name()}">
<xsl:apply-templates select="@*|node()"/>
</xsl:element>
</xsl:template>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>