XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
+ Stylus Studio Technical Forum (14621)
+ Website Feedback (249)
- XSLT Help and Discussion (7625)
-> + How to change XSLT parameter s... (3)
-> + how to change format of the da... (2)
-> + Search "Next 8 Results " doesn... (2)
-> - Support for Git (1)
-> + newbee (8)
-> + How to substitute element or t... (2)
-> + Xalan support in x16? (2)
-> + The context item for axis step... (5)
-> - ASP to XSL (1)
-> + xsl report, with xml feed, SVG... (7)
-> + XSLT code to transform CSV typ... (2)
-> + Make xstl file working in brow... (4)
-> + identity template, result-docu... (6)
-> - identity template and xsl:resu... (1)
-> + java.lang.RuntimeException: Er... (5)
-> + How to check matching parenthe... (2)
-> - Error only on using xalan:eval... (1)
-> + XSLT not displaying SOAP respo... (2)
-> + How do i delete the node from ... (2)
-> + How to break xslt lines to mak... (4)
-> - Marge node using attribute val... (1)
-> - Replce utf to unicode using xs... (1)
-> - getting different instances of... (1)
-> + XML to Flat (4)
-> + non breaking space   in e... (2)
-> - How can i attach a empty names... (1)
-> + Cannot find a matching 1-argum... (7)
-> - get value from different docum... (1)
-> + How can I change the XML heade... (2)
-> + Stylus Studio and Datapower (9)
-> + Generate XML form a XSD (2)
-> + There is no way to run xslt tr... (3)
-> + XML-Source NS is copied into t... (3)
-> + new guy attempting xslt (2)
-> + XML 2011 question (7)
-> + Manipulating XML with external... (2)
-> - removing duplicates from xml w... (8)
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> ->removing duplicates from ...
-> + Wnat to use presence of tag t... (2)
-> + modifing Andrew Welch's csv 2 ... (5)
-> + Can't use (or see) XSLT or WYS... (3)
-> + Delete the xsi:nil attribute ... (2)
-> + FOTY0012: Cannot get the typed... (20)
-> + XSLT Mapper - Two way xslt map... (2)
-> + EDI (5)
-> + XSL Test for lack of XML eleme... (4)
-> + Trouble Calling a java functio... (4)
-> + How to generate EDI 997 (2)
-> + followup on tokenize with /r (5)
-> + tokenize a string with \r (4)
-> + How to convert XML to XLS file... (2)
-> - How to convert XML to XLS file... (1)
-> + how to pass value to xsl for t... (3)
-> + entity expansion liimit exceed... (4)
-> + Creating XSLT Stylesheet (2)
-> + Create XSLT from XSD (2)
-> + How to remove nodes from xml b... (4)
-> + Highlighting text in XSL file (4)
-> - XSLT to Excel, predefine cell ... (1)
-> + CSaxon8Driver issue...time out (2)
-> + Is it possible to generate a X... (2)
-> + Is there any tool which genera... (2)
-> + xslt to html producing double ... (2)
-> - ADD 2 XML 2 Generate Single XM... (1)
-> + converting XML1 to XML2 struct... (2)
-> + How to remove the name space i... (2)
-> + Dump Payload into String (4)
-> + Converting Global EDIFACT into... (2)
-> + Auto mapping of XSLT? (3)
-> + Numbering a list broken into m... (3)
-> + help in xsl:analyze-string (2)
-> + Use XSLT with SOAP (2)
-> + Order of Processing Child Elem... (2)
-> + XSL finding a node based on va... (2)
-> + grouping a group? (11)
-> + Query on Looping (5)
-> + java.lang.Assertionerror_: Slo... (7)
-> + CONVERT SQL Server data to XML... (11)
-> + Error using "xsltproc" command... (3)
-> + XML refresh via web broswer (3)
-> + XSL-mapping usage for csv file... (4)
-> + form controls with xslt (2)
-> + Stylus Studio 2011 XML Enterpr... (2)
-> + Looping through Itema and gett... (2)
-> + Image src through System Varia... (3)
-> + XSL-mapping usage for csv file... (3)
-> + How to achieve UTF-8 encoding ... (2)
-> + sorting Using JavaScript (6)
-> + Display values from .xml horiz... (5)
-> + query on xslt for-each (3)
-> + query on xslt for-each (2)
-> + issue for First occurance (2)
-> + XSL: Mapping 2 XSD to 1 XSD (2)
-> + xslt mapper looses linkage fro... (2)
-> - How to Modify only few nodes a... (1)
-> + XSLT autocomplete function (2)
-> + i need to display dynamic list... (2)
-> + How to group when source has m... (11)
-> - Using EXCEL to create XSLT for... (1)
-> + Mapper generating XSLT, popula... (2)
-> + multiple columns (2)
-- [1-20] [21-40] [41-60] Next
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Tom BoyceSubject: removing duplicates from xml wtih xslt
Author: Tom Boyce
Date: 16 Jul 2013 07:39 PM
I have a need to remove duplicate values in repeating nodes. I've found several examples around the web and studied them enough to try them in my project. When I do, I get the error: XTSE0010: An xsl:template element must not contain an xsl:key element. I'm uploading the source and xslt that's giving this error.

I feel pretty confident I've recreated the example properly. I'm not sure if this is a code problem or maybe some quirk with SS 2011. I"ve specified 1.0 and the example is for this version.

Thanks in advance for any help.


UnknownVendor_Generic_XML.XML
Source xml

UnknownVendor_Generic_XML(1).XML
xslt file

Postnext
Ivan PedruzziSubject: removing duplicates from xml wtih xslt
Author: Ivan Pedruzzi
Date: 17 Jul 2013 01:02 PM
Tom

You have attached the input document twice but the XSLT is missing.

The error reported by Saxon seems to be pretty clear.

Are you sure that xsl:key is defined as direct child of xsl:stylesheet?


Ivan Pedruzzi
Stylus Studio Team

Postnext
Tom BoyceSubject: removing duplicates from xml wtih xslt
Author: Tom Boyce
Date: 17 Jul 2013 01:08 PM
I believe I did. sorry about the posting error, let me post the xslt


UnknownRemoveDups_Generic.xsl

Postnext
Ivan PedruzziSubject: removing duplicates from xml wtih xslt
Author: Ivan Pedruzzi
Date: 17 Jul 2013 03:19 PM

I am not sure what you are trying to output but the XSLT contains several errors

1) on line 5 you have declared xsl:key under xsl:template, and as mentioned in previous post this shoudl be udenr xsl:stylesheet

2) the identity template tries to copy attribute after generating text nodes

3) xsl:copy should wrap all template body


Attached here you can find a syntactically correct version which does not mean that its output is what you want. but this is a far as we can go without seeing the desired result


Ivan Pedruzzi
Stylus Studio Team


DocumentRemoveDups_Generic_ivan.xsl

Postnext
Tom BoyceSubject: removing duplicates from xml wtih xslt
Author: Tom Boyce
Date: 17 Jul 2013 03:22 PM
I don't see the attachment.

Postnext
Tom BoyceSubject: removing duplicates from xml wtih xslt
Author: Tom Boyce
Date: 17 Jul 2013 03:22 PM
see it now

Postnext
Tom BoyceSubject: removing duplicates from xml wtih xslt
Author: Tom Boyce
Date: 17 Jul 2013 03:41 PM
Thanks for your response. I'm not very practiced at xslt so please be patient.

ok, when I run the changes you make I now get the error: SXXP0003: Error reported by XML parser: Content is not allowed in prolog.

at com.exln.stylus.CSaxon8Driver.doProcessing(CSaxon8Driver.java:281)
at com.exln.stylus.CProcessorDriver.process(CProcessorDriver.java:104)
Vendor_Generic_XML.XML (1, 1)

This is line 1
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:a="http://www.ibm.com/maximo">

I have to have this line in there.
when I run just the generic line for stylesheet i get this error:

SXXP0003: Error reported by XML parser: The prefix "xsl" for element "xsl:stylesheet" is not bound.

at com.exln.stylus.CSaxon8Driver.doProcessing(CSaxon8Driver.java:269)
at com.exln.stylus.CProcessorDriver.process(CProcessorDriver.java:104)


what I am trying to output is an xml file exactly like the input xml except with the duplicate values for the nodes under ABCD_COMPCODE elenent.

As an example in the original xml you have these elements/values where
<ABCD_COMPANYCODE>1223</ABCD_COMPANYCODE>
<ABCD_COMPANYNAME>ABCD Productions</ABCD_COMPANYNAME>

occur more than once. I want the duplicate nodes to be removed:

<ABCD_COMPCODE>
<ABCD_COMPANYCODE>1223</ABCD_COMPANYCODE>
<ABCD_COMPANYNAME>ABCD Productions Inc</ABCD_COMPANYNAME>
</ABCD_COMPCODE>
<ABCD_COMPCODE>
<ABCD_COMPANYCODE>1224</ABCD_COMPANYCODE>
<ABCD_COMPANYNAME>ABCD Regional TV Inc</ABCD_COMPANYNAME>
</ABCD_COMPCODE>
<ABCD_COMPCODE>
<ABCD_COMPANYCODE>1223</ABCD_COMPANYCODE>
<ABCD_COMPANYNAME>ABCD Productions Inc</ABCD_COMPANYNAME>
</ABCD_COMPCODE>
<ABCD_COMPCODE>
<ABCD_COMPANYCODE>1223</ABCD_COMPANYCODE>
<ABCD_COMPANYNAME>ABCD Productions Inc</ABCD_COMPANYNAME>
</ABCD_COMPCODE>

Posttop
Ivan PedruzziSubject: removing duplicates from xml wtih xslt
Author: Ivan Pedruzzi
Date: 17 Jul 2013 08:47 PM
The input document had an extra character at the start of the file which made it not well formed

See solution attached



Ivan Pedruzzi
Stylus Studio Team


DocumentVendor_Generic_XML_1.XML


UnknownRemoveDups_Generic_ivan(1).xsl

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.