使用 XSLT 删除节点中的重复值
Removing Duplicate Values in Nodes using XSLT
我有以下XML:
<?xml version="1.0" encoding="utf-8" ?>
<SLOCDETAILS>
<INPUT>
</INPUT>
<TABLES>
<OUTPUT>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T150</SLOC>
<MATNR>220250</MATNR>
<CHARG>112233</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>223344</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>445566</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>667788</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>998877</CHARG>
</item>
</OUTPUT>
</TABLES>
</SLOCDETAILS>
我的 XSLT 如下:
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xalan="http://xml.apache.org/xalan" version="1.0">
<xsl:template match="/">
<Rowsets>
<Rowset Name="List">
<xsl:for-each select="SLOCDETAILS/TABLES/OUTPUT/item">
<Row>
<PLANT>
<xsl:value-of select="PLANT"/>
</PLANT>
<SLOC>
<xsl:value-of select="SLOC"/>
</SLOC>
<Material>
<xsl:value-of select="MATNR"/>
</Material>
<Batch>
<xsl:value-of select="CHARG"/>
</Batch>
</Row>
</xsl:for-each>
</Rowset>
</Rowsets>
</xsl:template>
</xsl:stylesheet>
我的结果 XML 是:
<?xml version="1.0" encoding="utf-8"?>
<Rowsets>
<Rowset Name="List">
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T150</SLOC>
<Material>220250</Material>
<Batch>112233</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>223344</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>445566</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>667788</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>998877</Batch>
</Row>
</Rowset>
</Rowsets>
现在我只想要独一无二的 SLOC。所以对于这个 XML,应该填充的 SLOC 应该是 <SLOC>T150</SLOC>
& <SLOC>T152</SLOC>
<SLOC>T152</SLOC>
被重复了 4 次。我想避免这种情况。
如何使用 XSLT 实现该目标?
我确定有一种分组方法可以使用。 XSLT 是否也提供了我们可以即插即用的独特价值类型的功能?解决此问题的不同方法将非常有帮助。
谢谢!
试一试:
<xsl:template match="/">
<Rowsets>
<Rowset Name="List">
<xsl:for-each select="SLOCDETAILS/TABLES/OUTPUT/item[not(SLOC = preceding-sibling::item/SLOC)]">
<Row>
<PLANT>
<xsl:value-of select="PLANT"/>
</PLANT>
<SLOC>
<xsl:value-of select="SLOC"/>
</SLOC>
<Material>
<xsl:value-of select="MATNR"/>
</Material>
<Batch>
<xsl:value-of select="CHARG"/>
</Batch>
</Row>
</xsl:for-each>
</Rowset>
</Rowsets>
</xsl:template>
我有以下XML:
<?xml version="1.0" encoding="utf-8" ?>
<SLOCDETAILS>
<INPUT>
</INPUT>
<TABLES>
<OUTPUT>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T150</SLOC>
<MATNR>220250</MATNR>
<CHARG>112233</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>223344</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>445566</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>667788</CHARG>
</item>
<item>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<MATNR>220250</MATNR>
<CHARG>998877</CHARG>
</item>
</OUTPUT>
</TABLES>
</SLOCDETAILS>
我的 XSLT 如下:
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xalan="http://xml.apache.org/xalan" version="1.0">
<xsl:template match="/">
<Rowsets>
<Rowset Name="List">
<xsl:for-each select="SLOCDETAILS/TABLES/OUTPUT/item">
<Row>
<PLANT>
<xsl:value-of select="PLANT"/>
</PLANT>
<SLOC>
<xsl:value-of select="SLOC"/>
</SLOC>
<Material>
<xsl:value-of select="MATNR"/>
</Material>
<Batch>
<xsl:value-of select="CHARG"/>
</Batch>
</Row>
</xsl:for-each>
</Rowset>
</Rowsets>
</xsl:template>
</xsl:stylesheet>
我的结果 XML 是:
<?xml version="1.0" encoding="utf-8"?>
<Rowsets>
<Rowset Name="List">
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T150</SLOC>
<Material>220250</Material>
<Batch>112233</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>223344</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>445566</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>667788</Batch>
</Row>
<Row>
<PLANT>INDIA</PLANT>
<SLOC>T152</SLOC>
<Material>220250</Material>
<Batch>998877</Batch>
</Row>
</Rowset>
</Rowsets>
现在我只想要独一无二的 SLOC。所以对于这个 XML,应该填充的 SLOC 应该是 <SLOC>T150</SLOC>
& <SLOC>T152</SLOC>
<SLOC>T152</SLOC>
被重复了 4 次。我想避免这种情况。
如何使用 XSLT 实现该目标?
我确定有一种分组方法可以使用。 XSLT 是否也提供了我们可以即插即用的独特价值类型的功能?解决此问题的不同方法将非常有帮助。
谢谢!
试一试:
<xsl:template match="/">
<Rowsets>
<Rowset Name="List">
<xsl:for-each select="SLOCDETAILS/TABLES/OUTPUT/item[not(SLOC = preceding-sibling::item/SLOC)]">
<Row>
<PLANT>
<xsl:value-of select="PLANT"/>
</PLANT>
<SLOC>
<xsl:value-of select="SLOC"/>
</SLOC>
<Material>
<xsl:value-of select="MATNR"/>
</Material>
<Batch>
<xsl:value-of select="CHARG"/>
</Batch>
</Row>
</xsl:for-each>
</Rowset>
</Rowsets>
</xsl:template>