Convert an XML file to HTML file using XSLT
Data is best stored in XML format, but the presentations are better in HTML. Here is a case where the following data in a XML file needs to be converted to a HTML file
Here is the XML File for conversion
< ?xml version="1.0" encoding="utf-8"? >
< !-- Sample File For Dot Net Tips & Tricks-- >
< !-- http://dotnetdud.blogspot.com -- >
< invoice InvNo="DND1232" InvDate="3-Oct-2008" >
< customer >
< custID >CID134< /custID >
< custName >Allirajan Ramachandran< /custName >
< /customer >
< items >
< item >
< MovieID >F123455< /MovieID >
< MovieName >Happy Days< /MovieName >
< RentedDate >3-Oct-2008< /RentedDate >
< ReturnDate >5-Oct-2008< /ReturnDate >
< /item >
< item >
< MovieID >F123462< /MovieID >
< MovieName >Lord Of Rings< /MovieName >
< RentedDate >3-Oct-2008< /RentedDate >
< ReturnDate >5-Oct-2008< /ReturnDate >
< /item >
< item >
< MovieID >F123232< /MovieID >
< MovieName >Drona< /MovieName >
< RentedDate >1-Oct-2008< /RentedDate >
< ReturnDate >3-Oct-2008< /ReturnDate >
< /item >
< /items >
< /invoice >
The XML file should be transformed to HTML using XSLT. This needs a stylesheet (XSL) defining what needs to be transformed and how it needs to be done.
Here is a sample stylesheet
< ?xml version="1.0" encoding="utf-8"? >
< !--
< !--
< !--
< !--
< xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
xmlns:vbadud="http://vbadud.in"
>
< msxsl:script implements-prefix="vbadud" language ="C#" >
< ![CDATA[
public string Defaulted(String RetDate)
{
if (DateTime.Parse(RetDate) < DateTime.Now)
{
return "Defaulted";
}
else
{
return "--";
}
}
public string Today()
{
return DateTime.Now.ToString();
}
]] >
< /msxsl:script >
< xsl:output method="html" indent="yes"/ >
< xsl:template match="invoice" >
< h1 >DND Video Library - Invoice< /h1 >
< p >
Invoice Date : =
< xsl:value-of select ="vbadud:Today()"/ >
< /p >
< p >
Invoice No : =
< xsl:value-of select ="@InvNo"/ >
< /p >
< xsl:apply-templates/ >
< /xsl:template >
< xsl:template match ="customer" >
=========== Customer Information =========
< br/ >
Customer ID :=
< xsl:value-of select ="custID"/ >
< br/ >
Customer Name :=
< xsl:value-of select ="custName"/ >
< br/ >
============================================
< br/ >
< xsl:apply-templates/ >
< /xsl:template >
< xsl:template match ="items" >
< table >
< th >Movie ID< /th >
< th >Movie Name< /th >
< th >Rented Date< /th >
< th >Return Date< /th >
< th >Defaulted< /th >
< xsl:apply-templates/ >
< /table >
< /xsl:template >
< xsl:template match ="item" >
< tr >
< td >< xsl:value-of select ="MovieID"/ > < /td >
< td >
< xsl:value-of select ="MovieName"/ >
< /td >
< td >
< xsl:value-of select ="RentedDate"/ >
< /td >
< td >
< xsl:value-of select ="ReturnDate"/ >
< /td >
< td >
< xsl:value-of select ="vbadud:Defaulted(ReturnDate)"/ >
< /td >
< /tr >
< /xsl:template >
< /xsl:stylesheet >
The above stylesheet uses C# scripting to identify defaulters
The following C# code will transform (convert) the XML to HTML
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Xml;
using System.Xml.XPath;
using System.Xml.Xsl;
public void transform_Xml2Html()
{
XslCompiledTransform XSLT = new XslCompiledTransform();
XsltSettings settings = new XsltSettings();
settings.EnableScript = true ;
XSLT.Load(@"c:\shasurdata\forblogger\VideoLibXSLTFile.xslt", settings, new XmlUrlResolver() );
XSLT.Transform(XMLFile ,@"c:\shasurdata\forblogger\SalesInvoice.html");
}
settings.EnableScript = true enables scripting in XSL file. The code uses XslCompiledTransform methods to convert the XML files
Simple isn’t it. Here you have the output:
HTML Source
< h1 xmlns:vbadud="http://vbadud.in" >DND Video Library - Invoice< /h1 >
< p xmlns:vbadud="http://vbadud.in" >
Invoice Date : =
04-10-2008 20:37:02< /p >
< p xmlns:vbadud="http://vbadud.in" >
Invoice No : =
DND1232< /p >
=========== Customer Information =========
< br xmlns:vbadud="http://vbadud.in" >
Customer ID :=
CID134< br xmlns:vbadud="http://vbadud.in" >
Customer Name :=
Allirajan Ramachandran< br xmlns:vbadud="http://vbadud.in" >
============================================
< br xmlns:vbadud="http://vbadud.in" >
CID134
Allirajan Ramachandran
< table xmlns:vbadud="http://vbadud.in" >
< th >Movie ID< /th >
< th >Movie Name< /th >
< th >Rented Date< /th >
< th >Return Date< /th >
< th >Defaulted< /th >
< tr >
< td >F123455< /td >
< td >Happy Days< /td >
< td >3-Oct-2008< /td >
< td >5-Oct-2008< /td >
< td >--< /td >
< /tr >
< tr >
< td >F123462< /td >
< td >Lord Of Rings< /td >
< td >3-Oct-2008< /td >
< td >5-Oct-2008< /td >
< td >--< /td >
< /tr >
< tr >
< td >F123232< /td >
< td >Drona< /td >
< td >1-Oct-2008< /td >
< td >3-Oct-2008< /td >
< td >Defaulted< /td >
< /tr >
< /table >
data:image/s3,"s3://crabby-images/dc362/dc3627dc95979c6934d9506e557ac31b756ad445" alt="Digg Digg"
data:image/s3,"s3://crabby-images/37d28/37d28971e185ef9e8311c45a45ddc3a91db07d1f" alt="Technorati Technorati"
data:image/s3,"s3://crabby-images/dde32/dde3201ed9ca80ca88e58748c87e1d7636a1c1ca" alt="Del.icio.us Delicious"
data:image/s3,"s3://crabby-images/5b5f7/5b5f702065509a8527fbd3a0f32d8995203f9e3b" alt="Stumble Upon StumbleUpon"
data:image/s3,"s3://crabby-images/e4475/e44757523e29a82837503c3f8f4919fd32a852f9" alt="reddit Reddit"
data:image/s3,"s3://crabby-images/f7bfd/f7bfd1570f4ea3d87c045f5204569cf3f63a908b" alt="BlinkList BlinkList"
data:image/s3,"s3://crabby-images/8c3cb/8c3cbf81229b4420836f78e7f004597bb616cde8" alt="Furl Furl"
data:image/s3,"s3://crabby-images/fad79/fad79a1011c7cd2f7e7387e6538e7455c806f1fc" alt="Mixx Mixx"
data:image/s3,"s3://crabby-images/2c5df/2c5dfb5c0e82f97d6ffd0d7b48221528fbc7072b" alt="facebook Facebook"
data:image/s3,"s3://crabby-images/b6de0/b6de02f05c758f991b13ff973facfb985dbdbf46" alt="Google Bookmark"
data:image/s3,"s3://crabby-images/f58e8/f58e89166d67b33b5f3acfc31edcb7e974e0697b" alt="Yahoo Myweb Yahoo"
data:image/s3,"s3://crabby-images/1dd2a/1dd2a4dbb75127a92b320b3e4309a3f2946d9f62" alt="ma.gnolia"
data:image/s3,"s3://crabby-images/b1797/b17976f4031ca0a59527cb21f8474b7ae02d7241" alt="squidoo"
data:image/s3,"s3://crabby-images/c85e0/c85e05127b41a992de7508ecf1e0de4276bc6428" alt="newsvine"
data:image/s3,"s3://crabby-images/d530d/d530dd27dada7c4e49c5ae2b0ec934e51d20af4d" alt="live"
data:image/s3,"s3://crabby-images/dec0a/dec0a62144ab4cc0f25d2570339be4c3bbab5927" alt="netscape"
data:image/s3,"s3://crabby-images/88c29/88c29e36ee3e3b19f745c1282054d658c013c6c2" alt="tailrank"
data:image/s3,"s3://crabby-images/3694f/3694f7907827daa5e4c6b4b3eebe3f5e901afe4f" alt="mister-wong"
data:image/s3,"s3://crabby-images/b54ab/b54abe9e659b2264b30d4cc16f2d39ba4ed54fc5" alt="blogmarks"
data:image/s3,"s3://crabby-images/c595b/c595b3ffde7a824069a6f8aac0357144b8c5003a" alt="slashdot"
data:image/s3,"s3://crabby-images/b8628/b86280f844536d038dbc72d310f8087d41bc9623" alt="spurl"
data:image/s3,"s3://crabby-images/577cc/577cc2e719b16d7921b9a58dd7ad8d3e7e04d344" alt="StumbleUpon"
No comments:
Post a Comment