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
Show tree view Topic
Topic Page 1 2 3 4 5 6 7 8 9 Go to previous topicPrev TopicGo to next topicNext Topic
Postnext
Chris YoullSubject: Help creating a comma delimited file
Author: Chris Youll
Date: 06 May 2009 10:26 PM
Hi,

I am trying to create a comma delimited output from a SOAP response using a stylesheet and I am not getting desired results. I have added sample XML input, the XSLT that I created and the output that I am receiving. I am not sure why I am receiving the 0 and X’s as the output. I would appreciate any help solving this.

Thank you,

Chris

-------------------XML File---------------------
<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:archns1="archserver.wsdl.dataflux.com"
xmlns:archns2="archserver.xsd.dataflux.com">
<SOAP-ENV:Body>
<archns2:SendArchitectServiceRequest>
<serviceName>ValidateAddressCondense.dmc</serviceName>
<fieldDefinitions>
<fieldName>ID</fieldName>
<fieldType>STRING</fieldType>
<fieldLength>15</fieldLength>
</fieldDefinitions>
<fieldDefinitions>
<fieldType>STRING</fieldType>
<fieldLength>50</fieldLength>
</fieldDefinitions>
<fieldDefinitions>
<fieldName>addr2</fieldName>
<fieldType>STRING</fieldType>
<fieldLength>50</fieldLength>
</fieldDefinitions>
<fieldDefinitions>
<fieldName>city</fieldName>
<fieldType>STRING</fieldType>
<fieldLength>35</fieldLength>
</fieldDefinitions>
<fieldDefinitions>
<fieldName>state</fieldName>
<fieldType>STRING</fieldType>
<fieldLength>28</fieldLength>
</fieldDefinitions>
<fieldDefinitions>
<fieldName>zip</fieldName>
<fieldType>STRING</fieldType>
<fieldLength>10</fieldLength>
</fieldDefinitions>
<dataRows>
<value>99</value>
<value>2530 S FOOTHILL RD</value>
<value></value>
<value>IDAHO FALLS</value>
<value>ID</value>
<value>83401</value>
</dataRows>
</archns2:SendArchitectServiceRequest>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>


--------------Stylesheet -----------------------------

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

<xsl:template match="fieldDefinitions">
<xsl:for-each select="fieldName">
<xsl:text>&#120;</xsl:text>
</xsl:for-each>
</xsl:template>

<xsl:template match="dataRows">
<xsl:text>&#10;</xsl:text>
<xsl:text>"</xsl:text>
<xsl:for-each select="value">
<xsl:value-of select="."/>
<xsl:text>","</xsl:text>
</xsl:for-each>
</xsl:template>

<xsl:template match="varValue">
<xsl:for-each select="varValue">
<xsl:text> </xsl:text>
</xsl:for-each>


<xsl:if test="position() = last()">
<xsl:text>"</xsl:text>
</xsl:if>
</xsl:template>

</xsl:stylesheet>

----------------Output ---------------
0
x
x
x
x
x
x
x
x
xxxxx
"99","2530 S FOOTHILL RD","","IDAHO FALLS","ID","83401","2530 S FOOTHILL RD","","AMMON","ID","83401-5937","US","0"," "

Postnext
John BamptonSubject: Help creating a comma delimited file
Author: John Bampton
Date: 07 May 2009 04:33 AM
<xsl:text>&#120;</xsl:text>

outputs a 'x'

Cheers, John Bampton

Postnext
Chris YoullSubject: Help creating a comma delimited file
Author: Chris Youll
Date: 07 May 2009 11:01 PM
Hi,
Sorry, I did not explain completely. I added the <xsl:text>&#120;</xsl:text> to add X’s to the front of the string so I had some string that I could look for to remove the record. What I would like to do is have just the comma delimited record without the X’s and the leading zero. If I remove the &#120; then I have a 0 in the string and I am not sure why.

Thanks,
Chris

Posttop
John BamptonSubject: Help creating a comma delimited file
Author: John Bampton
Date: 08 May 2009 08:14 AM
Originally Posted: 08 May 2009 08:10 AM
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:archns2="archserver.xsd.dataflux.com"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="text"></xsl:output>
<xsl:template match="archns2:SendArchitectServiceRequest" >
<xsl:apply-templates select="dataRows"></xsl:apply-templates>
</xsl:template>
<xsl:template match="dataRows">
<xsl:for-each select="value">
<xsl:text>"</xsl:text>
<xsl:value-of select="."/>
<xsl:text>"</xsl:text>
<xsl:if test="position() != last()">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>

Cheers, John Bampton.

 
Topic Page 1 2 3 4 5 6 7 8 9 Go to previous topicPrev TopicGo to next topicNext Topic
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.