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
Anne-Lie WahlbergSubject: concatenate many fields to one field via xsl
Author: Anne-Lie Wahlberg
Date: 21 Sep 2005 04:03 PM
Hi

I have a source xml-file containing a section with the following structure:

...
<Form ID="6" FormDataID="1720">
<field>
<name>Title</name>
<value>TestTitle</value>
</field>
<field>
<name>Requestor</name>
<value>Testperson</value>
</field>
<field>
<name>Email</name>
<value>testperson@somewhere.com</value>
</field>
<field>
<name>Telephone</name>
<value>0123-2345678</value>
</field>
<field>
<name>Costlocation</name>
<value>401000</value>
</field>
<field>
<name>EarlyStartDate</name>
<value>2005-05-05</value>
</field>
<field>
<name>Deliverydate</name>
<value>2005-09-21</value>
</field>
<field>
<name>Application</name>
<value>SomeApp</value>
</field>
<field>
<name>NewApplication</name>
<value>NewApp</value>
</field>
<field>
<name>Description</name>
<value>A description of some sort</value>
</field>
<field>
<name>OtherApplication</name>
<value>OtherApp</value>
</field>
<field>
<name>TimeForDelivery</name>
<value>15:00</value>
</field>
</Form>
...

The requested result in xml after a transformation through xsl is:
...
<PROPERTY NAME="REQUESTOR" TYPE="string">
<VALUE>Testperson</VALUE>
</PROPERTY>
<PROPERTY NAME="EARLYSTART" TYPE="string">
<VALUE>2005-05-05 15:00</VALUE>
</PROPERTY>
<PROPERTY NAME="DEADLINE" TYPE="string">
<VALUE>2005-09-21 12:00</VALUE>
</PROPERTY>
<PROPERTY NAME="CI" TYPE="string">
<VALUE>SomeApp</VALUE>
</PROPERTY>
<PROPERTY NAME="OTHER" TYPE="string">
<VALUE>Title&#13;&#10;TestTitle&#13;&#10;&#13;&#10;Email&#13;&#10;testperson@somewhere.com&#13;&#10;&#13;&#10;Telephone&#13;&#10;0123-2345678&#13;&#10;&#13;&#10;Costlocation&#13;&#10;401000&#13;&#10;&#13;&#10;New application&#13;&#10;NewApp&#13;&#10;&#13;&#10;Description&#13;&#10;A description of some sort&#13;&#10;&#13;&#10;OtherApplication&#13;&#10;OtherApp&#13;&#10;&#13;&#10;</VALUE>
</PROPERTY>
...

The required fields are requestor, earlystart (earlystartdate), deadline (deliverydate), and ci (application). The mapping of theese fields are Ok.
The rest of the field elements in the source xml have to be concatenated into one element (OTHER) in the target xml.

The number of field elements will vary between runs but at least the required field elements will always be in the source xml.

For now I have the following solution

...
<xsl:for-each select="Form/field">
...
<PROPERTY NAME="OTHER" TYPE="string">
<VALUE>
<xsl:value-of select="name"/>
<xsl:value-of disable-output-escaping="yes" select="$cr" />
<xsl:value-of select="value"/>
<xsl:value-of disable-output-escaping="yes" select="$cr" />
<xsl:value-of disable-output-escaping="yes" select="$cr" />
</VALUE>
</PROPERTY>
</xsl:for-each>
...
and it gives me the following result:
...
<PROPERTY NAME="OTHER" TYPE="string">
<VALUE>New Application&#13;&#10;NewApp&#13;&#10;&#13;&#10;</VALUE>
</PROPERTY>
<PROPERTY NAME="OTHER" TYPE="string">
<VALUE>Description&#13;&#10;A description of some sort&#13;&#10;&#13;&#10;</VALUE>
</PROPERTY>
<PROPERTY NAME="OTHER" TYPE="string">
<VALUE>Other application&#13;&#10;OtherApp&#13;&#10;&#13;&#10;</VALUE>
</PROPERTY>
...
If anybody can help me I'd be really happy, I'm out of ideas :o(

Thank's in advance
Anne-Lie

Postnext
Ivan PedruzziSubject: concatenate many fields to one field via xsl
Author: Ivan Pedruzzi
Date: 21 Sep 2005 04:47 PM

<?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:template match="/">
<ROOT>
<xsl:for-each select="Form/field[ name = 'Requestor' or name = 'EarlyStartDate' or name = 'Deliverydate' or name = 'Application']">
<PROPERTY NAME="{name}" TYPE="string">
<xsl:value-of select="value"/>
</PROPERTY>
</xsl:for-each>

<PROPERTY NAME="OTHER" TYPE="string">

<xsl:for-each select="Form/field[name != 'Requestor' and name != 'EarlyStartDate' and name != 'Deliverydate' and name != 'Application']">
<xsl:value-of select="name"/><xsl:text>
</xsl:text><xsl:value-of select="value"/><xsl:text>
</xsl:text>
</xsl:for-each>
</PROPERTY>
</ROOT>
</xsl:template>

</xsl:stylesheet>


Hope this helps
Ivan Pedruzzi
Stylus Studio Team

Posttop
Anne-Lie WahlbergSubject: concatenate many fields to one field via xsl
Author: Anne-Lie Wahlberg
Date: 21 Sep 2005 05:12 PM
Hi

It finally works! Thank's a million :o)

/Anne-Lie

   
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.