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)
-> + Use of before and after string (3) Sticky Topic
-> - How do I substitute element ty... (1)
-> + How does one add working days ... (4)
-> - Help, I have existing XLT and... (1)
-> + Need help on XSLT issue - (2)
-> + EDI to XML Conversion (7)
-> - XML To JSON Conversion using X... (1)
-> + Formatting Paragraphs to same ... (2)
-> - Grouping of records (1)
-> + Problems with xsd 1.1 (4)
-> + XML to HL7 mapping (3)
-> + XSLT 3 and Iterate (2)
-> + XSL-FO to PDF preview (3)
-> + java.lang.RuntimeException: Er... (2)
-> + Create Acroforms with Stylus X... (2)
-> + 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)
-- [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
richard pottsSubject: XSL to ''normalise" an xml structure
Author: richard potts
Date: 07 Oct 2004 06:41 AM
Hi everyone,

I'm hoping someone can help me with XSL to transform from a 'non-normalised' xml structure to a 'normalised' xml structure.

E.g. for the element <PIDHex> 2A23 <PIDHex> there are two 'records' in the non normalised xml (but there maybe more than two in other cases).
And I want to extract the common elements to form a single 'record' for <PIDHex> 2A23 <PIDHex> and add any non unique information in a new 'sub tag' called <Bytes>

I include example data files for you to understand.

I'd like to implement this purely in XSL if possible. (I'm using msxml 4)


If it helps the structure could possibly be changed to <PID id ="2A23"service="IO" type="BitMapped" use="Production"> so you only need to look at attributes instead of 'sub-tag values.

Any clues/or suggestions would be much appreciated, as I'm new to xsl

Thanks in advance

Non-Normalised xml

<Generic_Part_II>
<Extract>
<ExtractSourceFileName>P2_59 Blank.xls</ExtractSourceFileName>
<ExtractDate>06 Oct 2004 14:59:31</ExtractDate>
</Extract>
<PIDs>

<PID service="IO" type="BitMapped" use="Production">
<PIDPin>1</PIDPin>
<PIDHex>2A23</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Spare Wheel Unit Tire Sensor Status</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>32</PIDSize>
<PIDBMByte>2</PIDBMByte>
<PIDBMBit>0</PIDBMBit>
<PIDBMBitSequence>16</PIDBMBitSequence>
<PIDBMBitDescription>Tire Temperature Out of Specification</PIDBMBitDescription>
<PIDBMIO>I/P</PIDBMIO>
<PIDBMZero>No (False)</PIDBMZero>
<PIDBMOne>Yes (True)</PIDBMOne>
<PIDDefaultLower>R</PIDDefaultLower>
<PIDExtendedLower>R/W</PIDExtendedLower>
<PIDExtendedUpper>W</PIDExtendedUpper>
<PIDComments>comm</PIDComments>
<ECUApplicablity>
<ECUVariant>1</ECUVariant>
<ECUVariant>2</ECUVariant>
</ECUApplicablity>
</PID>
<PID service="IO" type="BitMapped" use="Production">
<PIDPin>2</PIDPin>
<PIDHex>2A23</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Spare Wheel Unit Tire Sensor Status</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>32</PIDSize>
<PIDBMByte>3</PIDBMByte>
<PIDBMBit>0</PIDBMBit>
<PIDBMBitSequence>8</PIDBMBitSequence>
<PIDBMBitDescription>Tire Pressure Out Of Specification</PIDBMBitDescription>
<PIDBMIO>O/P</PIDBMIO>
<PIDBMZero>No (False)</PIDBMZero>
<PIDBMOne>Yes (True)</PIDBMOne>
<PIDDefaultLower>W</PIDDefaultLower>
<PIDExtendedLower/>
<PIDExtendedUpper/>
<PIDComments/>
<ECUApplicablity/>
</PID>
<PID service="IO" type="SED" use="Production">
<PIDPin>1</PIDPin>
<PIDHex>2A17</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Rear Left Tire Sensor Wheel Unit Operation Mode</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>8</PIDSize>
<PIDSEDValue>01</PIDSEDValue>
<PIDSEDStateDesciption>Driving mode DP driving fast</PIDSEDStateDesciption>
<PIDDefaultLower>R</PIDDefaultLower>
<PIDExtendedLower>R/W</PIDExtendedLower>
<PIDExtendedUpper>W</PIDExtendedUpper>
<PIDComments>comm</PIDComments>
<ECUApplicablity>
<ECUVariant>1</ECUVariant>
<ECUVariant>1</ECUVariant>
</ECUApplicablity>
</PID>
<PID service="IO" type="SED" use="Production">
<PIDPin/>
<PIDHex>2A17</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Rear Left Tire Sensor Wheel Unit Operation Mode</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>8</PIDSize>
<PIDSEDValue>05</PIDSEDValue>
<PIDSEDStateDesciption>ICT test (HW interrupt) &amp; LF</PIDSEDStateDesciption>
<PIDDefaultLower>R</PIDDefaultLower>
<PIDExtendedLower>R/W</PIDExtendedLower>
<PIDExtendedUpper>R</PIDExtendedUpper>
<PIDComments>&lt;&gt;"'AA&amp;&amp;</PIDComments>
<ECUApplicablity/>
</PID>
<PID service="IO" type="SED" use="Production">
<PIDPin/>
<PIDHex>2A18</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Spare Wheel Unit Tire Pressure Status</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>8</PIDSize>
<PIDSEDValue>03</PIDSEDValue>
<PIDSEDStateDesciption>Test mode &amp; 135kPa&lt;P&lt;350kPa
&amp; DP parking slow</PIDSEDStateDesciption>
<PIDDefaultLower>W</PIDDefaultLower>
<PIDExtendedLower>W</PIDExtendedLower>
<PIDExtendedUpper>W</PIDExtendedUpper>
<PIDComments/>
<ECUApplicablity/>
</PID>
</PIDs>
</Generic_Part_II>


Normalised - xml
<?xml version="1.0"?>
<ASL>
<PIDs>
<PID service="RW" type="BitMapped" use="Production">
<PIDHex>2A23</PIDHex>
<PIDRange>Vehicle Manufacturer Specific</PIDRange>
<PIDDescription>Spare Wheel Unit Tire Sensor Status</PIDDescription>
<PIDParamNumber>0</PIDParamNumber>
<PIDSize>32</PIDSize>
<Bytes>
<Byte>
<PIDPin>1</PIDPin>
<PIDBMByte>2</PIDBMByte>
<PIDBMBit>0</PIDBMBit>
<PIDBMBitSequence>16</PIDBMBitSequence>
<PIDBMBitDescription>Tire Temperature Out of Specification</PIDBMBitDescription>
<PIDBMIO>I/P</PIDBMIO>
<PIDBMZero>No (False)</PIDBMZero>
<PIDBMOne>Yes (True)</PIDBMOne>
<PIDDefaultLower>R</PIDDefaultLower>
<PIDExtendedLower>R/W</PIDExtendedLower>
<PIDExtendedUpper>W</PIDExtendedUpper>
<PIDProgramLower>N/A</PIDProgramLower>
<PIDProgramUpper>R</PIDProgramUpper>
<PIDComments>comm</PIDComments>
<ECUApplicablity>
<ECUVariant>1</ECUVariant>
<ECUVariant>2</ECUVariant>
</ECUApplicablity>
</Byte>
<Byte>
<PIDPin>2</PIDPin>
<PIDBMByte>3</PIDBMByte>
<PIDBMBit>0</PIDBMBit>
<PIDBMBitSequence>8</PIDBMBitSequence>
<PIDBMBitDescription>Tire Temperature Out of Specification</PIDBMBitDescription>
<PIDBMIO>O/P</PIDBMIO>
<PIDBMZero>No (False)</PIDBMZero>
<PIDBMOne>Yes (True)</PIDBMOne>
<PIDDefaultLower>W</PIDDefaultLower>
<PIDExtendedLower></PIDExtendedLower>
<PIDExtendedUpper></PIDExtendedUpper>
<PIDProgramLower></PIDProgramLower>
<PIDProgramUpper></PIDProgramUpper>
<PIDComments></PIDComments>
<ECUApplicablity></ECUApplicablity>
</Byte>
</Bytes>
</PID>
</PIDs>
</ASL>



Postnext
Ivan PedruzziSubject: XSL to ''normalise
Author: Ivan Pedruzzi
Date: 11 Oct 2004 12:40 AM
Hi Richard,


The following stylesheet should solve your problem


<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:key name="PID" match="Generic_Part_II/PIDs/PID" use="concat(@service, @type)"/>
<xsl:key name="PID_children" match="Generic_Part_II/PIDs/PID/*" use="concat(../@service, ../@type, name(.), .)"/>

<xsl:template match="/">

<ASL>
<PIDs>
<!--
- group PID by service + type
- eliminate duplicates
-->
<xsl:apply-templates select="Generic_Part_II/PIDs/PID[ generate-id() = generate-id(key('PID', concat(@service, @type))[1])]"/>
</PIDs>
</ASL>
</xsl:template>

<xsl:template match="PID">
<xsl:copy>
<xsl:copy-of select="@*"/>

<!-- copy common elements -->
<xsl:for-each select="*[count(key('PID_children', concat(../@service, ../@type, name(.), . ))) &gt; 1]">
<xsl:copy-of select="."/>
</xsl:for-each>

<Bytes>
<xsl:for-each select="key('PID', concat(@service, @type))">
<byte>
<xsl:for-each select="*[count(key('PID_children', concat(../@service, ../@type, name(.), . ))) = 1]">
<xsl:copy-of select="."/>
</xsl:for-each>
</byte>
</xsl:for-each>
</Bytes>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>

Posttop
richard pottsSubject: XSL to ''normalise
Author: richard potts
Date: 12 Oct 2004 06:05 AM
Thanks for your help - it's been useful

   
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.