So, I tried to investigate this, and I'm almost completely leaving. I found a way to embed XSL in XML on dpawson.co.uk , but I cannot figure out what I'm doing wrong. I searched the Internet, trying to find solutions and explanations, but no one seemed to get an answer.
I am trying to create a single file that is server independent, so I can send one file to my colleagues in the hope that they will be able to view the file by opening it in their web browser.
Here is my code:
<?xml version="1.0" encoding="ISO-8859-1"?> <?xml-stylesheet type="text/xml" href="#stylesheet"?> <!DOCTYPE doc [ <!ATTLIST xsl:stylesheet id ID #REQUIRED> ]> <doc> <xsl:stylesheet id="stylesheet" version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" > <xsl:template match="xsl:stylesheet" /> <xsl:variable name="a" select="list/movie/seen[@value ='Yes']" /> <xsl:variable name="b" select="list/movie/seen" /> <xsl:variable name="c" select="sum(list/movie/rating/@value)" /> <xsl:variable name="d" select="$c div count($a)" /> <xsl:variable name="e" select="count($a) div count($b)" /> <xsl:variable name="f" select="list/movie/seen[@value ='No']" /> <xsl:variable name="g" select="list/movie/seen[@value ='Prior']" /> <xsl:variable name="h" select="count($f) div count($b)" /> <xsl:variable name="j" select="count($g) div count($b)" /> <xsl:variable name="minutes_total" select="sum(list/movie/length[@value ='y'])" /> <xsl:variable name="minutes" select="$minutes_total mod 60" /> <xsl:variable name="hours" select="floor($minutes_total div 60) mod 24" /> <xsl:variable name="hours2" select="floor($minutes_total div 60)" /> <xsl:variable name="days" select="floor($hours2 div 24)" /> <xsl:decimal-format name="percent" /> <xsl:decimal-format name="average" decimal-separator="." /> <xsl:template match="/doc"> <html> <head> <style> h2{ font-family: Courier, Courier New, monospace; font-size: 32px; text-decoration: underline; } body{ font-family: Courier New, monospace; } p{ font-size: 16px; } table{ font-size: 14px; } .title{ text-align:left; } .release{ text-align:center; } .seen{ text-align:center; } .rating{ text-align:right; } .length{ text-align:center; } </style> </head> <body> <h2>My Movie List</h2> <p>Movies seen so far: <xsl:value-of select="count($a)" />/<xsl:value-of select="count($b)" /> = <xsl:value-of select="format-number($e, '#%', 'percent')" /><br /> Movies yet to see: <xsl:value-of select="count($f)" />/<xsl:value-of select="count($b)" /> = <xsl:value-of select="format-number($h, '#%', 'percent')" /><br /> Movies seen prior to making list: <xsl:value-of select="count($g)" />/<xsl:value-of select="count($b)" /> = <xsl:value-of select="format-number($j, '#%', 'percent')" /><br /> Total time watched: <xsl:value-of select="format-number($days, '#0')" /> days, <xsl:value-of select="format-number($hours, '#0')" /> hours, <xsl:value-of select="format-number($minutes, '#0')" /> minutes<br /> Average rating: <xsl:value-of select="format-number($d, '#.000', 'average')" /> stars out of 5</p> <br /> <table border="1"> <tr> <th>#</th> <th>Title</th> <th>Release Date</th> <th>Length</th> <th>Seen</th> <th>Rating</th> </tr> <xsl:for-each select="list/movie"> <xsl:choose> <xsl:when test='seen = "Yes"'> <tr style="background-color:#666; color:#fff"> <td> <xsl:number /></td> <td class="title"><xsl:value-of select="title"/></td> <td class="release"><xsl:value-of select="release"/></td> <td class="length"><xsl:value-of select="length" /> minutes</td> <td class="seen"><xsl:value-of select="seen"/></td> <td class="rating"><xsl:value-of select="rating"/></td> </tr> </xsl:when> <xsl:when test='seen = "Seen prior to making list"'> <tr style="background-color:#999; color:#000"> <td> <xsl:number /></td> <td class="title"><xsl:value-of select="title"/></td> <td class="release"><xsl:value-of select="release"/></td> <td class="length"><xsl:value-of select="length"/> minutes</td> <td class="seen"><xsl:value-of select="seen"/></td> <td class="rating"><xsl:value-of select="rating"/></td> </tr> </xsl:when> <xsl:otherwise> <tr style="background-color:#fff;"> <td> <xsl:number /></td> <td class="title"><xsl:value-of select="title"/></td> <td class="release"><xsl:value-of select="release"/></td> <td class="length"><xsl:value-of select="length" /> minutes</td> <td class="seen"><xsl:value-of select="seen"/></td> <td class="rating"><xsl:value-of select="rating"/></td> </tr> </xsl:otherwise> </xsl:choose> </xsl:for-each> </table> </body> </html> </xsl:template> </xsl:stylesheet> <list> <movie> <title>2001: A Space Odyssey</title> <release>1968</release> <seen value="No">No</seen> <rating>N/A</rating> <length value="n">141</length> </movie> <movie> <title>28 Days Later</title> <release>2002</release> <seen value="No">No</seen> <rating>N/A</rating> <length value="n">113</length> </movie> <movie> <title>28 Weeks Later</title> <release>2007</release> <seen value="No">No</seen> <rating>N/A</rating> <length value="n">100</length> </movie> <movie> <title>A Clockwork Orange</title> <release>1971</release> <seen value="Yes">Yes</seen> <rating value="2">☆☆☆★★</rating> <length value="y">136</length> </movie> </list> </doc>
This is a list of films that contain as much as I have seen so far, how many I have not seen, how many I saw before I compiled the list, the total amount of time I added to watching movies and the average rating for watching a movie.
The problem is that all variables are displayed with a zero value, which leads to division by zeros, which also give a NaN value for some output.
Anything you can offer will be greatly appreciated!