File APIs for Java Developers
Manipulate DOC, XLS, PPT, PDF and many others from your application.
The moose likes XML and Related Technologies and the fly likes report writing using XML Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Engineering » XML and Related Technologies
Bookmark "report writing using XML" Watch "report writing using XML" New topic

report writing using XML

Anuj Anand
Ranch Hand

Joined: Nov 18, 2000
Posts: 96
I have been asked to read an XML file and generate a report output .For e.g just like reports generated out of Client server architecture . I wanted to ask that what would be the best way for that and whether we can use any report writing tools along with a XML parser.
Ajith Kallambella

Joined: Mar 17, 2000
Posts: 5782
Both XSLT Transformations with static stylesheets (XSL) and dynamic output generation using parsers are viable solutions to your problem.
However, doing it using a parser may not be the most efficient way since a parser "strips off" the XML document into atomic pieces and you need to put them together again!! A parser was never intended to be used for this purpose. On the other hand, an XSLT transformation walks through the XML tree transforming each node into some output format.
I am not sure if there are any specific report generation tools compatible with XML documents. Even if there are some, they will be using XSLT transformations behind the screens. So to get started with your assignment, finalize on the structure of your XML documents( get the DTD if it is available, ) get the required output format and start writing the XSL.

Open Group Certified Distinguished IT Architect. Open Group Certified Master IT Architect. Sun Certified Architect (SCEA).
Anuj Anand
Ranch Hand

Joined: Nov 18, 2000
Posts: 96
Hi Ajith
Well the structure of the doucment will not be fixed .However the XML needs to act like a transformation engine .For e.g the report structure on one day can be
Lets say report strucure is
Premium Rate Total
400 600 24000
The next day i get a different input file say

So report can be like
500 500 250000
Also there should be provision for sorting,order by etc all conditions .I was thinking of an idea that for sorting and order by, i enter that variable in input file .Then using that variable and the input file,the XML input file and using the parser i dynamically generate the report which could be infact an HTML .Since my knowledge of XMl is limited i wanted to ensure whether this could be done

Mapraputa Is
Leverager of our synergies

Joined: Aug 26, 2000
Posts: 10065
Anuj, for report generating tools you can check - a lot of free (and not so free ) software available.
To add something to what Ajith already said. XSLT, the language, has two remarkable features:
1) your XSLT program can be data-driven. It means you do not have to specify a path to walk the tree, instead, you can provide a set of templates (generic or specific ones) and your templates will be applied depending on what data in an XML document are
2) introspection functions, such as name() which output current node name.
By combining these features, we can build very flexible XSLT programs to process XML documents of almost any structure. For example, this XSLT
<xsl:stylesheet version='1.0' xmlns:xsl=''>
<xsl:template match="AMOUNT">
<xsl:template match="node()">
<xsl:value-of select="name()"/>: <xsl:value-of select="." /><br/>
<xsl:template match="text()"/>
Being applied to your first XML, outputs:
RATE: 600
And the same XSLT being fed your second document produces:
TOTAL1: 500
TOTAL2: 500

XSLT can change processing logic dynamically, based on either information in input XML document or input parameters, so your idea about putting an variable for sorting in an input file will work. It is a bit tricky, though. There is an idiom to achieve dynamic sorting:
<xsl:variable name="sortFields" select=�your field here� />
<xsl:sort select=�*[name(.)=$sortFields]">
and, as far as I can understand, there is performance penalty for such �dynamics�, but it can be done.
Of course, all this can be achieved with DOM/Java also, so you have a choice. My personal opinion is that for this class of tasks you can be more productive using XSLT than using DOM � after you become comfortable with XSLT, the language. If you all you need is to quickly process a couple of files and you are initially more comfortable with DOM, then XSLT can bring too much learning overhead. In long run XSLT is worth to bury yourself in.
[This message has been edited by Mapraputa Is (edited May 18, 2001).]

Uncontrolled vocabularies
"I try my best to make *all* my posts nice, even when I feel upset" -- Philippe Maquet
Mapraputa Is
Leverager of our synergies

Joined: Aug 26, 2000
Posts: 10065
Some Chinese painter said: �when I paint the Nature, there is no me, it�s the Nature who paints herself through my brush�. That�s what XSLT is about.
Sorry for being too philosophical, it�s Friday night...
I agree. Here's the link:
subject: report writing using XML
It's not a secret anymore!