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 BoothSubject: newbie question
Author: Chris Booth
Date: 27 Jan 2005 06:46 AM
XML:
<lines>
<line type="Hire" serialised="true" ecoded="true">
<lineWeeklyRate>140.000</lineWeeklyRate>
<linePriceMultiplied>2135.0</linePriceMultiplied>
<lineQtyMultiplied>4270.0000</lineQtyMultiplied>
<accessories>
<accessory mandatory="mandatory">
<lineWeeklyRate>100</lineWeeklyRate>
<linePriceMultiplied>500</linePriceMultiplied>
<lineQtyMultiplied>1000</lineQtyMultiplied>
<warnings/>
<itemTexts/>
</accessory>
</accessories>
</line>
<line type="Hire" serialised="true" ecoded="true">
<lineWeeklyRate>140.000</lineWeeklyRate>
<linePriceMultiplied>2135.0</linePriceMultiplied>
<lineQtyMultiplied>4270.0000</lineQtyMultiplied>
<accessories/>
</line>
</lines>

I need to do the following:

For each line I need to summate the lineWeeklyRate of the line and any accessories that belong to that line.
I have tried the following and I know I need to use some sort of for-each or position, because at present the template is called for each line and summates ALL lines and accessories, hence giving the same total on all lines.

<xsl:template name="lineTotalForfait">
<xsl:variable name="mainLine"><xsl:value-of select="format-number(sum(/roots/root/record/header/lines/line/lineWeeklyRate),'########0.00')"/></xsl:variable>
<xsl:variable name="accessory"><xsl:value-of select="format-number(sum(lineWeeklyRate),'########0.00')"/></xsl:variable>
<xsl:value-of select="$mainLine + $accessory" />
</xsl:template>

Any ideas?
This is driving me mad and I know it is quite simple.

Kind Regards and Many Thanks in Advance

Chris Booth - UK

Posttop
Ivan PedruzziSubject: newbie question
Author: Ivan Pedruzzi
Date: 28 Jan 2005 03:43 PM

Assuming your input document is

<?xml version="1.0"?>
<lines>
<line type="Hire" serialised="true" ecoded="true">
<lineWeeklyRate>140.000</lineWeeklyRate>
<linePriceMultiplied>2135.0</linePriceMultiplied>
<lineQtyMultiplied>4270.0000</lineQtyMultiplied>
<accessories>
<accessory mandatory="mandatory">
<lineWeeklyRate>100</lineWeeklyRate>
<linePriceMultiplied>500</linePriceMultiplied>
<lineQtyMultiplied>1000</lineQtyMultiplied>
<warnings/>
<itemTexts/>
</accessory>
</accessories>
</line>
<line type="Hire" serialised="true" ecoded="true">
<lineWeeklyRate>140.000</lineWeeklyRate>
<linePriceMultiplied>2135.0</linePriceMultiplied>
<lineQtyMultiplied>4270.0000</lineQtyMultiplied>
<accessories/>
</line>
</lines>

Running the following

<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<xsl:value-of select="format-number(sum(lines/line//lineWeeklyRate),'########0.00')"/>
</xsl:template>
</xsl:stylesheet>

produces 380.00 (140 + 100 + 140)

Hope this helps
Ivan

 
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.