我的XSL怎么了?

时间:2018-01-30 05:16:16

标签: xml xslt xslt-2.0

我试图将我的XML样式放入表中,但我根本没有运气。

目前我试图将数据打印到一个表中,但它只打印标题而不是数据,这里出了什么问题?

这是我的意思: https://imgur.com/a/O284v

我的XML格式正确。 我的XSL可能有问题

XML

<?xml version="1.0"?>
<?xml-stylesheet href="catalog.xsl" type="text/xsl"?>

<catalog>
<book id="bk101">
  <author>Gambardella, Matthew</author>
  <title>XML Developer's Guide</title>
  <genre>Computer</genre>
  <price>44.95</price>
  <publish_date>2000-10-01</publish_date>
  <description>An in-depth look at creating applications 
  with XML.</description>
 </book>
 <book id="bk102">
  <author>Ralls, Kim</author>
  <title>Midnight Rain</title>
  <genre>Fantasy</genre>
  <price>5.95</price>
  <publish_date>2000-12-16</publish_date>
  <description>A former architect battles corporate zombies, 
  an evil sorceress, and her own childhood to become queen 
  of the world.</description>
 </book>
 <book id="bk103">
  <author>Corets, Eva</author>
  <title>Maeve Ascendant</title>
  <genre>Fantasy</genre>
  <price>5.95</price>
  <publish_date>2000-11-17</publish_date>
  <description>After the collapse of a nanotechnology 
  society in England, the young survivors lay the 
  foundation for a new society.</description>
 </book>
 <book id="bk104">
  <author>Corets, Eva</author>
  <title>Oberon's Legacy</title>
  <genre>Fantasy</genre>
  <price>5.95</price>
  <publish_date>2001-03-10</publish_date>
  <description>In post-apocalypse England, the mysterious 
  agent known only as Oberon helps to create a new life 
  for the inhabitants of London. Sequel to Maeve 
  Ascendant.</description>
 </book>
 <book id="bk105">
  <author>Corets, Eva</author>
  <title>The Sundered Grail</title>
  <genre>Fantasy</genre>
  <price>5.95</price>
  <publish_date>2001-09-10</publish_date>
  <description>The two daughters of Maeve, half-sisters, 
  battle one another for control of England. Sequel to 
  Oberon's Legacy.</description>
 </book>
 <book id="bk106">
  <author>Randall, Cynthia</author>
  <title>Lover Birds</title>
  <genre>Romance</genre>
  <price>4.95</price>
  <publish_date>2000-09-02</publish_date>
  <description>When Carla meets Paul at an ornithology 
  conference, tempers fly as feathers get ruffled.</description>
 </book>
 <book id="bk107">
  <author>Thurman, Paula</author>
  <title>Splish Splash</title>
  <genre>Romance</genre>
  <price>4.95</price>
  <publish_date>2000-11-02</publish_date>
  <description>A deep sea diver finds true love twenty 
  thousand leagues beneath the sea.</description>
 </book>
 <book id="bk108">
  <author>Knorr, Stefan</author>
  <title>Creepy Crawlies</title>
  <genre>Horror</genre>
  <price>4.95</price>
  <publish_date>2000-12-06</publish_date>
  <description>An anthology of horror stories about roaches,
  centipedes, scorpions  and other insects.</description>
 </book>
 <book id="bk109">
  <author>Kress, Peter</author>
  <title>Paradox Lost</title>
  <genre>Science Fiction</genre>
  <price>6.95</price>
  <publish_date>2000-11-02</publish_date>
  <description>After an inadvertant trip through a Heisenberg
  Uncertainty Device, James Salway discovers the problems 
  of being quantum.</description>
 </book>
 <book id="bk110">
  <author>O'Brien, Tim</author>
  <title>Microsoft .NET: The Programming Bible</title>
  <genre>Computer</genre>
  <price>36.95</price>
  <publish_date>2000-12-09</publish_date>
  <description>Microsoft's .NET initiative is explored in 
  detail in this deep programmer's reference.</description>
 </book>
 <book id="bk111">
  <author>O'Brien, Tim</author>
  <title>MSXML3: A Comprehensive Guide</title>
  <genre>Computer</genre>
  <price>36.95</price>
  <publish_date>2000-12-01</publish_date>
  <description>The Microsoft MSXML3 parser is covered in 
  detail, with attention to XML DOM interfaces, XSLT processing, 
  SAX and more.</description>
 </book>
 <book id="bk212">
  <author>Galos, Mike</author>
  <title>Visual Studio 7: A Comprehensive Guide</title>
  <genre>Computer</genre>
  <price>49.95</price>
  <publish_date>2001-04-16</publish_date>
  <description>Microsoft Visual Studio 7 is explored in depth,
  looking at how Visual Basic, Visual C++, C#, and ASP+ are 
  integrated into a comprehensive development 
  environment.</description>
 </book>
</catalog>

XSL

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:output method="html" />

<xsl:template match="catalog">

    <html>
    <head>
        <title>Books Catalog by Author</title>
    </head>

    <body>
        <h1>Books Catalog by Author</h1>

        <table border ="1" cellpadding ="5">
            <xsl:for-each-group select="book" group-by="author">
                <xsl:sort select="current-grouping-key()" />

            <tr bgcolor="#ef9f37">

            <td colspan="4">
            Author:
            <xsl:value-of select="current-grouping-key()" />

            </td>
    </tr>
    </xsl:for-each-group>

    <tr>
        <td>ID</td>
        <td>Title</td>
        <td>Genre</td>
        <td>Price</td>
    </tr>

    <!-- <xsl:for-each-group select="current-group()" group-by="@id" />
    <xsl:sort select="current-grouping-key()" />
    <tr>
    <td>
        <xsl:value-of select="@id" />    -->


        </table>
    </body>
    </html>

    </xsl:template>
</xsl:stylesheet>

1 个答案:

答案 0 :(得分:0)

您的脚本失败的原因是您关闭了for-each-group循环 太早。它实际上只打印作者 - &#34; head&#34;书组。

应构建模板中有关table标记的部分 如下:

  1. for-each-group(外部)循环,正如您所做的那样。

  2. 作者和标题(2行),就像你一样。

  3. 仍然在此外圈中,放置一个for-each循环, 循环遍历当前组的内容(特定作者的书籍)。

  4. 其内容应输出一行(<tr>标签)并在其中输出4个单元格 (<td>标签)具有适当的内容。第一个包含id 当前book的属性,以及其余 - 所选的值 儿童标签(标题流派价格)。

  5. 因此,您的模板应如下所示:

    <xsl:template match="catalog">
      <html>
        <head>
          <title>Books Catalog by Author</title>
        </head>
        <body>
          <h1>Books Catalog by Author</h1>
          <table border ="1" cellpadding ="5">
            <xsl:for-each-group select="book" group-by="author">
              <xsl:sort select="current-grouping-key()" />
              <tr bgcolor="#ef9f37">
                <td colspan="4">Author:
                  <xsl:value-of select="current-grouping-key()" />
                </td>
              </tr>
              <tr>
                <td>ID</td><td>Title</td><td>Genre</td><td>Price</td>
              </tr>
              <xsl:for-each select="current-group()">
                <tr>
                  <td><xsl:value-of select="@id"/></td>
                  <td><xsl:value-of select="title"/></td>
                  <td><xsl:value-of select="genre"/></td>
                  <td><xsl:value-of select="price"/></td>
                </tr>
              </xsl:for-each>
            </xsl:for-each-group>
          </table>
        </body>
      </html>
    </xsl:template>
    

    顺便说一句:您的概念是for-each-group@id分组书籍 很奇怪请注意,每本书都有不同 id ,因此没有组 会包含超过1本书。