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)
-> + Remove leading Zeros from a st... (4)
-> + how to parse a html element fo... (2)
-> + Add namespaces to target messa... (2)
-> + XSLT Transformation - insertin... (3)
-> + Convert binary xml (9)
-> + XSLT Transformation (4)
-> + Generating hyperlinks (3)
-> + XSLT to PDF problem (with JAVA... (2)
-> + how to add onclick_ with try/c... (2)
-> + Keep table in one page. xsl-fo... (4)
-> + Cannot find a matching 2-argum... (3)
-> + Creating one string from a sub... (2)
-> + XSLT: Traversing XML twice for... (6)
-> + Copy element without namespace... (5)
-> + Create dynamic elemant name (2)
-> - XSLT: Traversing XML twice for... (3)
-> ->XSLT: Traversing XML twic...
-> ->XSLT: Traversing XML twic...
-> + Problem including Javascript (2)
-> + Looping through attributes (4)
-> + Transform values into elements... (4)
-> + Problem with deep node copy an... (2)
-> + Comparing Dates With ASP.NET 2... (3)
-> + Converting tree structure to h... (4)
-> + Attributes to element transfor... (2)
-> + XSLT transformation (2)
-> + XSLT transformation (5)
-> + xsl:character-map not working (2)
-> + Removing duplicates entries. (2)
-> + Image issues. (2)
-> + xsl transformation (4)
-> + XSL Question (5)
-> + how to insert xml file as an n... (2)
-> + Document Function (2)
-> + convert seconds to hh:mm:ss (5)
-> + how to remove attribute while ... (3)
-> + XSL-FO question (2)
-> + EDI 997 creation. (7)
-> + Line break within a tag in XML... (2)
-> + Contact Help Needed (2)
-> + ACK 997 (2)
-> + XSLT to output XML( which conf... (11)
-> + Retrieving all nodes where a c... (6)
-> + Verifying XML and XSD within X... (4)
-> + How to validate date format in... (3)
-> + XSLT question (2)
-> + Muenchian grouping (2)
-> + How to remove specific text en... (8)
-> + If Else Condition along with L... (2)
-> + SAXON Problem (2)
-> + comapring global variable valu... (2)
-> + copying the value of xsl in va... (2)
-> + Urgent:XSLT element value sel... (2)
-> + Ignoring first element using f... (2)
-> + EDI X12 to XML (4)
-> + XSLT FOR-EACH HELP (2)
-> + Sorting Help Needed (3)
-> + XSLT help with linking (2)
-> + selecting data into node set b... (2)
-> + Watch and Variable in Debug no... (4)
-> + Transforming XML to XML - grou... (2)
-> + Saxon 9.0 B support in debug m... (2)
-> + Repeating element question (2)
-> + Newly Purchased Version Not La... (2)
-> + xsl:include not finding file (5)
-> + JAXP and XSLT 2.0 / XPATH 2.0 (2)
-> + ASP:DropDownList trigger in Xs... (2)
-> + Auto-Skip empty values (2)
-> + retrieving a javascript functi... (2)
-> + need help (2)
-> + html tag ignored (2)
-> + Quick reply needed (8)
-> + xslt to remove namespaces but ... (2)
-> - Using a WSDL definition in an ... (1)
-> + XSL logic issue for simple inp... (6)
-> + Regarding XML namespace prefix... (4)
-> + Mapper reoganizes itself. (8)
-> + XSL Substring Removal (2)
-> + Regarding XSLT logic for a sim... (3)
-> + XSLT Transform documentation (2)
-> + XSLT stack trace in case of er... (3)
-> + No New Line (2)
-> - No New Line (1)
-> + howto loop through a sequence (2)
-> + xml and xsl and whitespace in... (2)
-> + XSL Date formatting (4)
-> + XSL to XSL Mapping using custo... (4)
-> + flat xml to nested xml comvers... (4)
-> + Including schema in scenario (2)
-> + DTDs and traversing (2)
-> + Help with transformation (2)
-> + Problem running XSLT against X... (2)
-> + Carriage return in the output (5)
-> + Generating XSLT to match a sch... (3)
-> + WYSIWYG editor (2)
-> + Grouping without For-Each (3)
-> + output XML using XSLT (8)
-> + Help configuring Xalan-j proce... (8)
-> + Convert Existing HTML pages to... (2)
-> + Generating Transformation - XS... (4)
-> + DOCTYPE public and system info... (2)
-> + Using EXSLT str:tokenize funct... (5)
-- Previous [661-680] [681-700] [701-720] Next
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Ramon AldanaSubject: XSLT: Traversing XML twice for XML + Text outputs
Author: Ramon Aldana
Date: 10 Jan 2008 10:56 PM
Hello,

I have both routines to traverse an XML and generate a true XML copy + a string concatenation as follows.

To get true XML copy of input document:

<xsl:template match="/">
<xsl:copy><xsl:copy-of select="*|@*"/><xsl:apply-templates/></xsl:copy>
</xsl:template>

To get string concatenation

<xsl:template match="/" >
<xsl:for-each select="procedure/parameters/attributes">
<xsl:if test="position()!=1">,</xsl:if>
@<xsl:value-of select="@name"/> <xsl:value-of select="@type"/> <xsl:if test="@required='No'">= NULL</xsl:if>
</xsl:for-each>
</xsl:template>


The problem is that I need the TEXT generated in the second xsl:template at the bottom of the XML generated by the first xsl:template.


Thanks.

Postnext
(Deleted User) Subject: XSLT: Traversing XML twice for XML + Text outputs
Author: (Deleted User)
Date: 11 Jan 2008 09:35 AM
Hi Ramon,
have you tried merging the two templates into one, one after the other?

Alberto

Posttop
Ramon AldanaSubject: XSLT: Traversing XML twice for XML + Text outputs
Author: Ramon Aldana
Date: 11 Jan 2008 01:59 PM
Thanks for you reply.

Yes, what I find is that inside...

Somehow as I was trying to repro what I did that didn't work according to your sugestion, it sudenly worked.

I believe my problem was that the initial: <xsl:template match="/" > was match-ing "*|@*" which then was doing the traversal for each single element/attribute and it was giving me duplicates all over the place.

Thanks.

For future knowledge here is what I did:

XML:
<procedure name="Reader.GetComponentById" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="C:\Users\rborjes\Documents\SD\whos\Databases\Procedures.xsd">
<scope>Public</scope>
<summary>Get a single component by Id</summary>
<parameters>
<attributes type="Int" required="yes" description="Component Id" name="ComponentId"/>
</parameters>
<returns>
<recordset>
<column datatype="varchar(300)" description="Component Name" name="name"/>
<column datatype="varchar(4000)" description="Description" name="description"/>
<column datatype="Int" description="Component Central Id" name="CompCentralId"/>
<column datatype="Int" description="Product Id" name="ProductId"/>
<column datatype="Int" description="Type Id" name="TypeId"/>
<column datatype="Int" description="Group Id" name="GroupId"/>
<column datatype="Int" description="Phase Id" name="PhaseId"/>
<column datatype="nvarchar(30)" description="Product Manager Owner" name="PMOwner"/>
<column datatype="nvarchar(30)" description="Developer Owner" name="DevOwner"/>
<column datatype="nvarchar(30)" description="Test Owner" name="TestOwner"/>
<column datatype="varchar(4000)" description="Comments" name="Comments"/>
</recordset>
<return description="General Error" value="1"/>
<return description="Success" value="0"/>
</returns>
<sample>
<description/>
<code/>
</sample>
</procedure>


XSLT:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:fn="http://www.w3.org/2005/xpath-functions">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes" omit-xml-declaration="yes"/>





<xsl:template match="/" >
<xsl:copy><xsl:copy-of select="*|@*"/><xsl:apply-templates/></xsl:copy>
CREATE procedure <xsl:value-of select="procedure/@name"/>
<xsl:for-each select="procedure/parameters/attributes">
<xsl:if test="position()!=1">,</xsl:if>
@<xsl:value-of select="@name"/><xsl:text> </xsl:text><xsl:value-of select="@type"/> <xsl:if test="@default !='' "> = <xsl:value-of select="@default"/></xsl:if>
</xsl:for-each>
WITH EXECUTE AS CALLER AS BEGIN


SELECT <xsl:for-each select="procedure/returns/recordset/column"><xsl:if test="position()!=1">,</xsl:if>CAST(0 AS <xsl:value-of select="@datatype"/>) AS <xsl:value-of select="@name"/></xsl:for-each>

</xsl:template>


</xsl:stylesheet>


OUTPUT:
<procedure xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="Reader.GetComponentById" xsi:noNamespaceSchemaLocation="C:\Users\rborjes\Documents\SD\whos\Databases\Procedures.xsd"> <scope>Public</scope>
<summary>Get a single component by Id</summary>
<parameters>
<attributes type="Int" required="yes" description="Component Id" name="ComponentId"/>
</parameters>
<returns>
<recordset>
<column datatype="varchar(300)" description="Component Name" name="name"/>
<column datatype="varchar(4000)" description="Description" name="description"/>
<column datatype="Int" description="Component Central Id" name="CompCentralId"/>
<column datatype="Int" description="Product Id" name="ProductId"/>
<column datatype="Int" description="Type Id" name="TypeId"/>
<column datatype="Int" description="Group Id" name="GroupId"/>
<column datatype="Int" description="Phase Id" name="PhaseId"/>
<column datatype="nvarchar(30)" description="Product Manager Owner" name="PMOwner"/>
<column datatype="nvarchar(30)" description="Developer Owner" name="DevOwner"/>
<column datatype="nvarchar(30)" description="Test Owner" name="TestOwner"/>
<column datatype="varchar(4000)" description="Comments" name="Comments"/>
</recordset>
<return description="General Error" value="1"/>
<return description="Success" value="0"/>
</returns>
<sample>
<description/>
<code/>
</sample>
</procedure>PublicGet a single component by Id
CREATE procedure Reader.GetComponentById
@ComponentId Int
WITH EXECUTE AS CALLER AS BEGIN


SELECT CAST(0 AS varchar(300)) AS name,CAST(0 AS varchar(4000)) AS description,CAST(0 AS Int) AS CompCentralId,CAST(0 AS Int) AS ProductId,CAST(0 AS Int) AS TypeId,CAST(0 AS Int) AS GroupId,CAST(0 AS Int) AS PhaseId,CAST(0 AS nvarchar(30)) AS PMOwner,CAST(0 AS nvarchar(30)) AS DevOwner,CAST(0 AS nvarchar(30)) AS TestOwner,CAST(0 AS varchar(4000)) AS Comments










   
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.