XSLT入门 -- 第3章 实践篇

转载 2007年10月14日 21:42:00

1 复制

这是个复制所有节点的例子(程序1)。例如从XHTML变换成XHTML等情况,源和结果的元素大部分相同时,就可以将该实例稍作修改,仅针对需要改动的部分书写代码即可。

程序1: copy.xsl
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<xsl:apply-templates/>
</xsl:template>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
使用xsl:xcopy元素将各节点进行递归复制。

 

2 行列交换

该实例可以将HTML表格的行和列进行交换(程序2)。

程序2: table.xsl
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml"/>
<xsl:template match="/">
<xsl:apply-templates/>
</xsl:template>
<xsl:template match="table">
<xsl:copy>
<xsl:apply-templates select="@*"/>
<xsl:for-each select="tr[1]/td">
<tr>
<xsl:variable name="x" select="last()"/>
<xsl:variable name="y" select="position()-1"/>
<xsl:for-each select="../../tr/td">
<xsl:if test="(position()-1) mod $x = $y">
<td>
<xsl:value-of select="."/>
</td>
</xsl:if>
</xsl:for-each>
</tr>
</xsl:for-each>
</xsl:copy>
</xsl:template>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
因为是交换行列,所以只需输出源表格的列数的行就可以了。在这里,使用
<xsl:for-each select="tr[1]/td">
循环,按照第一行的列数来新建行(tr元素)。使用如下循环
<xsl:for-each select="../../tr/td">
来取出各行中将要保存的数据。由于当前节点是tr[1]/td,那么使用../tdと将仅能取出第一行的td元素。为了取出所有td元素,须写成../../tr/td的形式。

 

变量x中保存新建表格的总行数,变量y中保存当前正在生成的行的行数-1。因此,

<xsl:if test="(position()-1) mod $x = $y">
使用该条件输出td元素中的数据。mod是取余数的运算符。

将如图1所示的页面(程序3)进行转换,可以得到如图2所示的输出结果。

图1: 输入页面
程序3: table.xml
<?xml version="1.0"?>
<html>
<head>
<title>表格</title>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
</head>
<h1>表格</h1>
<body>
<table border="1">
<tr>
<td>甲</td>
<td>乙</td>
<td>丙</td>
<td>丁</td>
<td>戊</td>
</tr>
<tr>
<td>己</td>
<td>庚</td>
<td>辛</td>
<td>壬</td>
<td>癸</td>
</tr>
</table>
</body>
</html>
图2: 输出页面

 

3 表格

表格可以看作是二维数组。让我们试着将它转换成一维数组。但是仅仅将表格内容排列出来就失去了意义,因此我们将保留原表格的行号和列号作为结果的属性值(程序4)。

程序4: databank.xsl
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<databank>
<xsl:apply-templates select=".//table"/>
</databank>
</xsl:template>
<xsl:template match="table">
<xsl:for-each select="tr">
<xsl:variable name="row" select="position()"/>
<xsl:for-each select="td">
<xsl:variable name="column" select="position()"/>
<data>
<xsl:attribute name="row">
<xsl:copy-of select="$row"/>
</xsl:attribute>
<xsl:attribute name="column">
<xsl:copy-of select="$column"/>
</xsl:attribute>
<xsl:value-of select="."/>
</data>
</xsl:for-each>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
将行号和列号的信息保存到变量row和column中。
<xsl:variable name="row" select="position()"/>
<xsl:variable name="column"select="position()"/>
使用row属性输出行号,column属性输出列号。
<xsl:attribute name="row">
<xsl:copy-of select="$row"/>
</xsl:attribute>
<xsl:attribute name="column">
<xsl:copy-of select="$column"/>
</xsl:attribute>
将程序3进行转换时,输出如下所示。
<?xml version="1.0" encoding="UTF-8"?>
<databank>
<data row="1" column="1">甲</data>
<data row="1" column="2">乙</data>
<data row="1" column="3">丙</data>
<data row="1" column="4">丁</data>
<data row="1" column="5">戊</data>
<data row="2" column="1">己</data>
<data row="2" column="2">庚</data>
<data row="2" column="3">辛</data>
<data row="2" column="4">壬</data>
<data row="2" column="5">癸</data>
</databank>

 

4 将表格转换为CSV文件

虽然XSLT一般用来将XML文档转换成XML文档,但是也能够输出XML文档之外的格式。下面是将含有table元素的HTML文档转换成CSV(Comma Separated Value)格式输出的例子(程序5)。 1

程序5: csv.xsl
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" encoding="UTF-8"/>
<xsl:template match="/">
<xsl:apply-templates select=".//tr"/>
</xsl:template>
<xsl:template match="tr">
<xsl:for-each select="td">
<xsl:value-of select="."/>
<xsl:if test="not(position()=last())">
<xsl:text>,</xsl:text>
</xsl:if>
</xsl:for-each>
<xsl:text>
</xsl:text>
</xsl:template>
</xsl:stylesheet>
为输出文本格式,需要指定
<xsl:output method="text" encoding="UTF-8"/>
由于被转换的对象节点是表示行的tr元素,因此针对tr元素定义模板规则。若不是行中的最后一个元素,则输出分隔符“,”。
<xsl:if test="not(position()=last())">
<xsl:text>,</xsl:text>
</xsl:if>
将程序3进行转换的结果如下所示。
甲,乙,丙,丁,戊
己,庚,辛,壬,癸
 

《C++程序设计原理与实践》部分习题答案 1

首先要声明,本人也是刚刚开始自学C++,用的书就是这本《C++程序设计原理与实践》,课后习题 都是自学完本章之后选做的。编程能力渣得拿不出手,如果有错误还请不吝赐教~另外,本人的时间管理有比较大的问题...
  • sinat_23857245
  • sinat_23857245
  • 2014年12月13日 19:26
  • 1310

算法竞赛入门经典(第二版)-刘汝佳-第三章 数组与字符串 例题+习题(17/18)

说明本文是我对第三章题目的练习总结,建议配合紫书——《算法竞赛入门经典(第2版)》阅读本文。 另外为了方便做题,我在VOJ上开了一个contest,欢迎一起在上面做:第三章contest例题例3-1...
  • thudaliangrx
  • thudaliangrx
  • 2016年02月19日 17:28
  • 3452

java语言程序设计基础篇第六章编程练习题

1 import java.util.Scanner; public class Main{ public static void main(String[] args){ final int...
  • gyhguoge01234
  • gyhguoge01234
  • 2016年07月05日 22:26
  • 3886

驱动入门:从WRK到IRP实践篇

  • 2015年04月13日 16:37
  • 101KB
  • 下载

android 3D系列之入门实践篇

By 何明桂(http://blog.csdn.net/hmg25) 转载请注明出处     通过之前文章--概念篇的学习,我们今天编写一个简单的入门程序,实现一个不断绕x轴,y轴旋转的彩色立方体,...
  • hmg25
  • hmg25
  • 2011年09月01日 14:49
  • 10216

从零单排入门机器学习:线性回归(linear regression)实践篇

线性回归(linear regression)实践篇 之前一段时间在coursera看了Andrew ng的机器学习的课程,感觉还不错,算是入门了。这次打算以该课程的作业为主线,对机器学习基本知识做一...
  • linger2012liu
  • linger2012liu
  • 2014年06月18日 20:43
  • 2758

WIFI 芯片ESP8266 开发视频教程(实践篇)

  • 2016年06月08日 22:22
  • 750B
  • 下载

目标管理与知识管理-实践篇

  • 2010年08月05日 10:51
  • 12.26MB
  • 下载

sap按生产订单成本核算_实践篇

  • 2012年01月26日 18:03
  • 1.95MB
  • 下载

软件测试之实践篇

  • 2007年11月06日 13:40
  • 1.56MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:XSLT入门 -- 第3章 实践篇
举报原因:
原因补充:

(最多只允许输入30个字)