Note that there are some explanatory texts on larger screens.

plurals
  1. POPresenting XML with xsl- TVGuide
    text
    copied!<p>I have this XML file and i need to trasform it via xsl/t to a table. </p> <pre><code>&lt;?xml version="1.0" encoding="ISO-8859-1"?&gt; &lt;TVGuide start="2001-07-05" end="2001-07-05"&gt; &lt;Channel&gt; &lt;Name&gt;BBC1&lt;/Name&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:00:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;A QuestionOfSport&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program rating="5" flag="favorite"&gt; &lt;Start&gt;2001-07-05T19:30:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;EastEnders&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;Description&gt; Mark's health scare forces him to reconsider his future with Lisa, while Jamie is torn between Sonia and Zoe. &lt;/Description&gt; &lt;CastList&gt; &lt;CastMember&gt; &lt;Character&gt;&lt;Name&gt;Zoe Slater&lt;/Name&gt;&lt;/Character&gt; &lt;Actor&gt;&lt;Name&gt;Michelle Ryan&lt;/Name&gt;&lt;/Actor&gt; &lt;/CastMember&gt; &lt;CastMember&gt; &lt;Character&gt;&lt;Name&gt;Jamie Mitchell&lt;/Name&gt;&lt;/Character&gt; &lt;Actor&gt;&lt;Name&gt;Jack Ryder&lt;/Name&gt;&lt;/Actor&gt; &lt;/CastMember&gt; &lt;CastMember&gt; &lt;Character&gt;&lt;Name&gt;Sonia Jackson&lt;/Name&gt;&lt;/Character&gt; &lt;Actor&gt;&lt;Name&gt;Natalie Cassidy&lt;/Name&gt;&lt;/Actor&gt; &lt;/CastMember&gt; &lt;/CastList&gt; &lt;Writers&gt; &lt;Writer&gt;&lt;Name&gt;Nick Saltrese&lt;/Name&gt;&lt;/Writer&gt; &lt;Writer&gt;&lt;Name&gt;Julie Wassmer&lt;/Name&gt;&lt;/Writer&gt; &lt;/Writers&gt; &lt;Director&gt;&lt;Name&gt;Stewart Edwards&lt;/Name&gt;&lt;/Director&gt; &lt;Producer&gt;&lt;Name&gt;Emma Turner&lt;/Name&gt;&lt;/Producer&gt; &lt;/Program&gt; &lt;Program type="documentary"&gt; &lt;Start&gt;2001-07-05T20:00:00&lt;/Start&gt; &lt;Duration&gt;PT45M&lt;/Duration&gt; &lt;Series&gt;&lt;/Series&gt; &lt;Title&gt;Get Real with Casualty&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T20:45:00&lt;/Start&gt; &lt;Duration&gt;PT45M&lt;/Duration&gt; &lt;Series&gt;Lottery&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T21:30:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;Panorama&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;/Channel&gt; &lt;Channel&gt; &lt;Name&gt;BBC2&lt;/Name&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;Snooker&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T20:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;HomeFront&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T21:00:00&lt;/Start&gt; &lt;Duration&gt;PT50M&lt;/Duration&gt; &lt;Series&gt;WildAfrica&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program flag="interesting"&gt; &lt;Start&gt;2001-07-05T21:50:00&lt;/Start&gt; &lt;Duration&gt;PT40M&lt;/Duration&gt; &lt;Series&gt;Taboo&lt;/Series&gt; &lt;Title&gt;Nakedness&lt;/Title&gt; &lt;/Program&gt; &lt;/Channel&gt; &lt;Channel&gt; &lt;Name&gt;ITV&lt;/Name&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:00:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;Emmerdale&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:30:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;CoronationStreet&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T20:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;Millionaire&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program type="drama"&gt; &lt;Start&gt;2001-07-05T21:00:00&lt;/Start&gt; &lt;Duration&gt;PT2H&lt;/Duration&gt; &lt;Series&gt;&lt;/Series&gt; &lt;Title&gt;Hot Money&lt;/Title&gt; &lt;/Program&gt; &lt;/Channel&gt; &lt;Channel&gt; &lt;Name&gt;Channel 4&lt;/Name&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:00:00&lt;/Start&gt; &lt;Duration&gt;PT55M&lt;/Duration&gt; &lt;Series&gt;Channel4News&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:55:00&lt;/Start&gt; &lt;Duration&gt;PT5M&lt;/Duration&gt; &lt;Series&gt;SlotArt&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T20:00:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;Brookside&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T20:30:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;Brookside&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T21:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;Swallow&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program flag="favorite"&gt; &lt;Start&gt;2001-07-05T22:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;AllyMcBeal&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;/Channel&gt; &lt;Channel&gt; &lt;Name&gt;Channel 5&lt;/Name&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:00:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;MovieChartShow&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program&gt; &lt;Start&gt;2001-07-05T19:30:00&lt;/Start&gt; &lt;Duration&gt;PT30M&lt;/Duration&gt; &lt;Series&gt;FiveNews&lt;/Series&gt; &lt;Title&gt;&lt;/Title&gt; &lt;/Program&gt; &lt;Program type="entertainment"&gt; &lt;Start&gt;2001-07-05T20:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H&lt;/Duration&gt; &lt;Series&gt;&lt;/Series&gt; &lt;Title&gt;The World's Worst Drivers Caught On Tape&lt;/Title&gt; &lt;/Program&gt; &lt;Program type="film"&gt; &lt;Start&gt;2001-07-05T21:00:00&lt;/Start&gt; &lt;Duration&gt;PT1H55M&lt;/Duration&gt; &lt;Series&gt;&lt;/Series&gt; &lt;Title&gt;Black and White&lt;/Title&gt; &lt;/Program&gt; &lt;/Channel&gt; &lt;/TVGuide&gt; </code></pre> <p>I know probably the problem is in the xsl file. I am not an expert and I will really appriciate your help.</p> <p>Here is the xsl file.</p> <pre><code>&lt;?xml version="1.0" encoding="UTF-8"?&gt; &lt;xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"&gt; &lt;xsl:key name="hatchala" match="/TVGuide/Channel/Program" use="Start"/&gt; &lt;xsl:template match="/"&gt; &lt;table border="1"&gt; &lt;tr&gt;hours &lt;xsl:call-template name="tvchan"/&gt; &lt;/tr&gt; &lt;tr&gt; &lt;th&gt; &lt;xsl:call-template name="hour"/&gt; &lt;/th&gt; &lt;/tr&gt; &lt;/table&gt; &lt;/xsl:template&gt; &lt;xsl:template name="tvchan"&gt; &lt;xsl:for-each select="/TVGuide/Channel"&gt; &lt;th&gt; &lt;td&gt; &lt;xsl:value-of select ="Name"/&gt; &lt;/td&gt; &lt;/th&gt; &lt;/xsl:for-each&gt; &lt;/xsl:template&gt; &lt;xsl:template name="hour"&gt; &lt;xsl:for-each select="/TVGuide/Channel/Program[not(./Start=following::Start)]"&gt; &lt;xsl:sort select="Start"/&gt; &lt;xsl:variable name="zman" select ="Start"/&gt; &lt;tr&gt; &lt;td&gt; &lt;xsl:value-of select="Start"/&gt; &lt;/td&gt; &lt;xsl:for-each select="/TVGuide/Channel/Program[Start=$zman]"&gt; &lt;xsl:variable name="name1"&gt; &lt;xsl:choose&gt; &lt;xsl:when test="Title!=''"&gt; &lt;xsl:value-of select="Title"/&gt; &lt;/xsl:when&gt; &lt;xsl:otherwise&gt; &lt;xsl:value-of select="Series"/&gt; &lt;/xsl:otherwise&gt; &lt;/xsl:choose&gt; &lt;/xsl:variable&gt; &lt;td&gt; &lt;xsl:value-of select="$name1"/&gt; &lt;/td&gt; &lt;/xsl:for-each&gt; &lt;/tr&gt; &lt;/xsl:for-each&gt; &lt;/xsl:template&gt; &lt;/xsl:stylesheet&gt; </code></pre> <p>The result should show a table with all the programs and they hours.</p> <p><a href="http://dl.dropbox.com/u/99771726/table.png" rel="nofollow">http://dl.dropbox.com/u/99771726/table.png</a> </p> <p>thank you very much for the help.</p>
 

Querying!

 
Guidance

SQuiL has stopped working due to an internal error.

If you are curious you may find further information in the browser console, which is accessible through the devtools (F12).

Reload