2016-03-05 91 views
1

我有一个包含多个team元素的XML文件。每个team元素都有多个player子元素。用xml和xslt分组输出

的基本结构如下

<league> 
     <team> 
      <!-- Team details go here --> 
      <player> 
         <!-- Player details go here --> 
      </player> 
     </team> 
</league> 

我需要的是要显示的团队的详细信息,然后在表中的玩家的输出。玩家应按姓氏排序,队名应按其姓名排序。

我得到的是一个接一个的团队细节,然后是所有球员的细节。

我已将以下xml简化为只有少数几个细节,以便于阅读。

这是我的XML

<league xmlns:xlink="http://www.w3.org/1999/xlink"> 

    <team> 

     <teamName>Southampton</teamName> 
     <manager>Ronald Koeman</manager> 
     <stadium>St. Mary's</stadium> 

     <players> 

      <firstName>Victor</firstName> 
      <surname>Wanyama</surname> 
      <squadNumber>12</squadNumber> 

     </players> 

     <players> 

      <firstName>Shane</firstName> 
      <surname>Long</surname> 
      <squadNumber>7</squadNumber> 
     </players> 

    </team> 

     <team> 

     <teamName>Arsenal</teamName> 
     <manager>Arsene Wenger</manager> 
     <stadium>Emirates Stadium</stadium> 

     <players> 

      <firstName>Hector</firstName> 
      <surname>Bellerin</surname> 
      <squadNumber>24</squadNumber> 

     </players> 

     <players> 

      <firstName>Santi</firstName> 
      <surname>Cazorla</surname> 
      <squadNumber>19</squadNumber> 
     </players> 

    </team> 
</league> 

而XSLT

<xsl:stylesheet version="2.0" 
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 

<xsl:template match="/"> 
<html> 

<head> 
    <link rel="stylesheet" type="text/css" href="epl.css" /> 
</head> 

<body> 
    <xsl:for-each select="league/team"> 
    <xsl:sort select="teamName"/> 

    <b>Name</b> 
    <p><xsl:value-of select="teamName" /></p> 

    <b>Manager</b> 
    <p><xsl:value-of select="manager" /></p> 

    <b>Stadium</b> 
    <p><xsl:value-of select="Stadium" /></p> 
    </xsl:for-each> 

    <tr> 
     <th>First Name</th> 
     <th>Surname</th> 
     <th>Squad Number</th> 
    </tr> 

    <xsl:for-each select="league/team/players"> 
    <xsl:sort select="surname"/> 
    <tr> 
    <td><xsl:value-of select="firstName"/></td> 
    <td><xsl:value-of select="surname"/></td> 
    <td><xsl:value-of select="squadNumber"/></td> 
    </tr> 
    </xsl:for-each> 

</body> 

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

我没有足够的代表表明了什么我得到的图像,但只是把我想将数据分组球队的球员数据与下表中的每个球队相关。

我试过了。

我试过以各种方式使用for-each-group。所有这些导致通用的“错误加载样式表:解析XSLT样式表失败。”在Firefox中。

<xsl:for-each-group select="league" group-by="@team"> <team name="{current-grouping-key()}"> </xsl:for-each-group

这包括将for-each-group在体内的开始,在它自己的xsl:模板,在主要的xsl:模板。

我已经尝试了“select”部分的备选xpath表达式。像league/team,,league/

我试过的嵌套在一起得到的球员和球队数据到XSL另一个用于-每个

我有XML工具插件记事本++安装并试图保存文件什么时候得到: XML解析埃罗在第51行:在样式表行数据标签的 过早结束3

51号线只有收盘</xsl:stylesheet>

一旦我删除for-each-group它正常保存但输出顺序不正确,正如我前面提到的。显示所有球队数据,然后显示所有球员数据,而无需将球员与球队联系起来。

回答

1

我认为您不需要在您的XSLT中进行分组,因为您的播放器数据已经按照您的XML分组。您只需要移动当前选择球员的xsl:for-each,以便嵌套在当前选择球队的球员中,然后调整选择语句,以便xpath表达式相对于当前的team元素。

试试这个XSLT

<xsl:stylesheet version="1.0" 
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 

<xsl:output method="html" doctype-public="XSLT-compat" omit-xml-declaration="yes" encoding="UTF-8" indent="yes" /> 

<xsl:template match="/"> 
    <html> 
    <head> 
     <link rel="stylesheet" type="text/css" href="epl.css" /> 
    </head> 
    <body> 
     <xsl:for-each select="league/team"> 
     <xsl:sort select="teamName"/> 
      <b>Name</b> 
      <p><xsl:value-of select="teamName" /></p> 
      <b>Manager</b> 
      <p><xsl:value-of select="manager" /></p> 
      <b>Stadium</b> 
      <p><xsl:value-of select="stadium" /></p> 
      <table> 
      <tr> 
       <th>First Name</th> 
       <th>Surname</th> 
       <th>Squad Number</th> 
      </tr> 
      <xsl:for-each select="players"> 
      <xsl:sort select="surname"/> 
       <tr> 
       <td><xsl:value-of select="firstName"/></td> 
       <td><xsl:value-of select="surname"/></td> 
       <td><xsl:value-of select="squadNumber"/></td> 
       </tr> 
      </xsl:for-each> 
      </table> 
      <br /> 
     </xsl:for-each> 
    </body> 
    </html> 
</xsl:template> 
</xsl:stylesheet> 
+0

感谢蒂姆,我曾试图嵌套在一起,但我错过了,我不得不改变XPath表达式的地步。无可否认,我花了大部分时间研究并试图为每个小组实施。这让我回头看着正确的方向,代码运行良好。再次感谢! – nod64