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)
-> + 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
graham drummondSubject: xsl:if test statement result to new element
Author: graham drummond
Date: 19 Jul 2011 06:40 AM
Hi,

Quite new to this, and having an issue using XSLT to transform and update XML. I have the XSLT creating 3 new elements and I need the result of an 'if' statement to go into one of the newly create elements. Any help would be much appreciated:

Part of XML:

<Customer>
<MortalityStatus>ALIVE</MortalityStatus>
</Customer>

XSLT:

<xsl:template match="//*[local-name() = 'CommunicationBody']">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
<xsl:element name="Deceased"></xsl:element>
<xsl:element name="FolderDelivery"></xsl:element>
<xsl:element name="Investigation"></xsl:element>
</xsl:copy>
</xsl:template>

<xsl:template match="//*[local-name() = 'MortalityStatus']">
<MortalityStatus>
<xsl:if test="text () ='ALIVE'">true</xsl:if>
</MortalityStatus>
</xsl:template>

Part of Current Output:

<Customer>
<MortalityStatus>true</MortalityStatus>
</Customer>
<Deceased/>
<FolderDelivery/>
<Investigation/>

Required Output:

<Customer>
<MortalityStatus>ALIVE</MortalityStatus>
</Customer>
<Deceased/>
<FolderDelivery>true</FolderDelivery>
<Investigation/>

Which of the 3 folders above it goes in is dependant on their MortalityStatus.

Postnext
Ivan PedruzziSubject: xsl:if test statement result to new element
Author: Ivan Pedruzzi
Date: 20 Jul 2011 07:19 PM
See if the following code helps

Ivan


<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output indent="yes"/>

<xsl:template match="CommunicationBody">
<xsl:copy>
<xsl:copy-of select="@*"/>
<xsl:apply-templates/>
<xsl:element name="Deceased"></xsl:element>
<xsl:element name="FolderDelivery">
<xsl:if test="Customer/MortalityStatus ='ALIVE'">
<xsl:text>true</xsl:text>
</xsl:if>
</xsl:element>
<xsl:element name="Investigation"></xsl:element>
</xsl:copy>
</xsl:template>

<xsl:template match="MortalityStatus">
<xsl:copy-of select="."/>
</xsl:template>

<xsl:template match="text()"/>

<xsl:template match="*">
<xsl:apply-templates/>
</xsl:template>

<xsl:template match="/">
<xsl:apply-templates/>
</xsl:template>

</xsl:stylesheet>

Postnext
graham drummondSubject: xsl:if test statement result to new element
Author: graham drummond
Date: 21 Jul 2011 03:40 AM
Originally Posted: 21 Jul 2011 03:38 AM
Hi Ivan, thank you for your help. I can get the elements populated and the 'true' result using the following:

<xsl:template match="//*[local-name() = 'CommunicationBody']">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
<xsl:element name="Deceased"></xsl:element>
<xsl:element name="FolderDelivery"><xsl:element>
<xsl:element name="InvestigationDelivery"></xsl:element>
</xsl:copy>
</xsl:template>

<xsl:template match="//*[local-name() = 'MortalityStatus']">
<MortalityStatus>
<xsl:if test="text ()='ALIVE'">
<xsl:text>true</xsl:text>
</xsl:if>
</MortalityStatus>
</xsl:template>

However, I need the result i.e. 'true' to appear in the FolderDelivery element and not in the MortalityStatus element. I need the MortalityStatus element to remain with 'ALIVE'.

Any ideas?

Posttop
Ivan PedruzziSubject: xsl:if test statement result to new element
Author: Ivan Pedruzzi
Date: 21 Jul 2011 11:39 AM
I advise against match expressions like the following, they are highly inefficient and difficult to maintain

//*[local-name() = 'MortalityStatus']

Have you tried the code I posted?



I also modified your source to match the "required output" as desribed in the original post

Hope this helps
Ivan


===============================
Input XML

<?xml version="1.0"?>
<CommunicationBody>
<Customer>
<MortalityStatus>ALIVE</MortalityStatus>
</Customer>
</CommunicationBody>

===============================
XSLT

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output indent="yes"/>

<xsl:template match="//*[local-name() = 'CommunicationBody']">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
<xsl:element name="Deceased"></xsl:element>
<xsl:element name="FolderDelivery">
<xsl:if test="Customer/MortalityStatus ='ALIVE'">
<xsl:text>true</xsl:text>
</xsl:if>
</xsl:element>
<xsl:element name="InvestigationDelivery"></xsl:element>
</xsl:copy>
</xsl:template>

<xsl:template match="//*[local-name() = 'MortalityStatus']">
<Customer>
<MortalityStatus>
<xsl:if test="text()='ALIVE'">
<xsl:value-of select="."/>
</xsl:if>
</MortalityStatus>
</Customer>
</xsl:template>
</xsl:stylesheet>


===============================
Output XML
<CommunicationBody>
<Customer>
<MortalityStatus>ALIVE</MortalityStatus>
</Customer>
<Deceased/>
<FolderDelivery>true</FolderDelivery>
<InvestigationDelivery/>
</CommunicationBody>

   
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.