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
Brandon H.Subject: Converting XML String Data to Numeric
Author: Brandon H.
Date: 08 Dec 2005 12:26 PM
I have a problem with numeric XML data coming into my XSL with comma separators. I need to somehow convert this comma separated number from the string that XSL thinks it is, into a numeric so I can use the result in a multiplication operation.

I have tried using the format-number() function no it, and it returns 'NaN'.

My only other thought is to somehow remove the commas from the string, and then convert the result into a numeric, and finally proceed with the math.

Any ideas?

Brandon

Postnext
Minollo I.Subject: Converting XML String Data to Numeric
Author: Minollo I.
Date: 08 Dec 2005 12:45 PM
Assuming the commas in the number can be safely removed without affecting the meaning of the number (as in the case where they are "thousands" markers), then you can easily do that using the translate() function:
<xsl:value-of select="translate('123,456', ',', '')"/>
...will output: 123456

Hope this helps,
Minollo

Posttop
Brandon H.Subject: Converting XML String Data to Numeric
Author: Brandon H.
Date: 08 Dec 2005 12:57 PM
Minollo,

Yes, this is exactly how I ended up doing it - also, to make sure the result of the translate comes out numeric you need to add the following:

<xsl:variable name="str2num" select="number(translate($someNum,',',''))" />

This will remove the commas and convert the string to a number - from there you can use the $str2num variable for any math needed.

Thanks for your help.

   
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.