我有一个 XML 文档:
<Gym>
<Trainee>
<Trainee_ID>1521</Trainee_ID>
<Trainee_Name>Mary Andersen</Trainee_Name>
<Trainee_Age>23</Trainee_Age>
</Trainee>
<Trainee>
<Trainee_ID>1522</Trainee_ID>
<Trainee_Name>Jane Sellers</Trainee_Name>
<Trainee_Age>56</Trainee_Age>
</Trainee>
<Trainee>
<Trainee_ID>1523</Trainee_ID>
<Trainee_Name>Julie Aniston</Trainee_Name>
<Trainee_Age>32</Trainee_Age>
</Trainee>
<Class>
<Trainee_ID>1521</Trainee_ID>
<Course_ID>A21</Course_ID>
<Class_Room>A1</Class_Room>
</Class>
<Class>
<Trainee_ID>1522</Trainee_ID>
<Course_ID>A22</Course_ID>
<Class_Room>B2</Class_Room>
</Class>
<Class>
<Trainee_ID>1523</Trainee_ID>
<Course_ID>B24</Course_ID>
<Class_Room>B3</Class_Room>
</Class>
<Course>
<Course_ID>A21</Course_ID>
<Course_Title>Yoga</Course_Title>
<Course_Hours_Per_Week>2</Course_Hours_Per_Week>
</Course>
<Course>
<Course_ID>A22</Course_ID>
<Course_Title>Pilates</Course_Title>
<Course_Hours_Per_Week>2</Course_Hours_Per_Week>
</Course>
<Course>
<Course_ID>B24</Course_ID>
<Course_Title>Aerobic</Course_Title>
<Course_Hours_Per_Week>3</Course_Hours_Per_Week>
</Course>
</Gym>
我想要做的是用 XSL 制作 3 个表,标题是子元素的名称(仅一次),子标题是孙元素的名称(仅一次),其余的行和列将填充值的孙子元素。
据我所知:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/Gym">
<html>
<body>
<xsl:for-each select="*">
<table border="1">
<tr>
<xsl:if test="position()='1' or position()='4' or position()='7'">
<xsl:value-of select="translate(name(.), 'abcdefghijklnmopqrstuvwxyz', 'ABCDEFGHIJKLNMOPQRSTUVWXYZ')"/>
</xsl:if>
</tr>
<tr>
<xsl:if test="position()='1' or position()='4' or position()='7'">
<xsl:for-each select="*">
<th><xsl:value-of select="name(.)"/></th>
</xsl:for-each>
</xsl:if>
</tr>
<tr>
<xsl:for-each select="*">
<th>
<xsl:value-of select="."/>
</th>
</xsl:for-each>
</tr>
</table>
<p></p>
</xsl:for-each>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
这是输出:
(来源:UploadScreenshot.com)
发生的事情是,每次为每个子元素创建一个新表时,但我想要的是一个智能代码,它将自动生成所有 3 个表,然后生成标题和子标题,然后输入数据. 我想要的是这样的(忽略颜色和文本格式):
我希望我的 XSLT 代码为每个元素实例创建一个表,然后将元素的名称作为标题,然后将子元素作为标题一次,然后用数据填充表。