I want to use XSLT to transform a set of documents into one structure. I have the transformation working correctly to concatenate the documents. I don’t know, however, whether the the documents have duplicate entries in them, which I will need to remove.
I need to know how to remove these duplicates (if they exist) by an id attribute. All duplicates will have the same id. I know it will have something to do with keys and generate-id functions.
<root>
<item id="1001">A</item>
<item id="1003">C</item>
<item id="1004">D</item>
<item id="1002">B</item>
<item id="1001">A</item>
<item id="1003">C</item>
<item id="1004">D</item>
<item id="1005">E</item>
</root>
I need an XSLT 1.0 transformation for the above, based on the following…
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
Also, would someone be able to explain how it works to me too? Bit of a noob…
Thanks in advance…
Commonly solutions are presented with the use of
generate-id()but personally I prefer a slightly different variation that doesn’t use generate-id:-First you create a key which holds the all item elements using the id attribute as the lookup key.
keygenerates an efficient index which can be used to look up items.The technique relies on the fact that when create a node-set using the
|operator you get a unique set of nodes. In other words if the same node is found on both sides of the|operator it only appears in the resulting set once.The expression:-
Will return the set of item nodes that have a specific ID. So:-
will return only one of the nodes that were found have that specific ID and is repeatable (that is using this expression repeatedly always returns the same node).
Hence the expression:-
is can only be true for one
itemnode with a specific id value.The
copy-oftherefore makes a deep copy of only one item node having a distinct id.