330 likes | 502 Views
使用 XSL 格式化 XML. 目标. 章节目标: 通过本章学习,你应该能够: 了解什么是 XSL 了解什么是 XPath 掌握 XPath 及其相关技术 掌握 XSL 模板及使用 掌握 XSL 节点的选择方法 了解 XSL 控制指令 掌握使用 XSL 对 XML 进行转换. 引言.
E N D
目标 • 章节目标: 通过本章学习,你应该能够: • 了解什么是XSL • 了解什么是XPath • 掌握XPath及其相关技术 • 掌握XSL模板及使用 • 掌握XSL节点的选择方法 • 了解XSL控制指令 • 掌握使用XSL对XML进行转换
引言 • XSL(Extensible Style Language)是可扩展样式语言,该语言有别于第六章所介绍的CSS层叠样式表语言,它是一个完全符合XML语法规范的语言,即XSL样式语言自生就是一个结构完整的XML文件。XSL样式语言主要由两个部分组成,即数据转换语言XSLT(XSL Transformations)和数据格式化语言XSL-FO(XSL Formatting Object)。XSLT转换语言是一种很有用的语言,它能够把数据从一种XML表示转变为另一种表示,由于它的这种特性,使它成为现代网络发展的新宠。这种功能使它成为基于XML的电子商务、电子数据交换、元数据交换及其它相同数据的不同表示之间进行转换的重要组成部分。使用各种数据的无障碍转换成为现实。
XSLT概述 目前,XSL是格式化显示XML源文档数据的最好选择。XML所具有的一切优点,XSL也都具备,在功能上又比CSS更为灵活强大,所以在输出显示时,应该首先考虑使用XSL来进行格式化。 CSS层叠样式表同样可以格式化XML文档,那么有了CSS为什么还需要XSL呢?因为CSS虽然能够很好的控制输出的样式,比如色彩,字体,大小等,但是它有严重的局限性,就是: (1) CSS不能重新排序文档中的元素; (2) CSS不能判断和控制哪个元素被显示,哪个不被显示; (3) CSS不能统计计算元素中的数据; 换句话说,CSS只适合用于输出比较固定的最终文档。CSS的优点是简洁,消耗系统资源少;而XSLT虽然功能强大,但因为要重新索引XML结构树,所以消耗内存比较多。 因此,常常将两种技术结合起来使用,比如在服务器端用XSLT处理文档,在客户端用CSS来控制显示,这样可以减少响应时间。
联系人 姓名 … 地址 联系人 街道 城市 省份 姓名 … 地址 街道 城市 省份 XSL与XPath XML文档结构树 根节点 <?xml version = "1.0" encoding="GB2312" standalone = "no"?> <?xml-stylesheet type="text/xsl" href="使用XSL显示联系人文档.xsl"?> 根元素 …
一个完整的XSL文档实例 见例7.2
XSL与XPath 通过前面的实例,我们可以看出,要将XML源文档的数据内容通过XSLT显示出来,其重要的部分就是如何获取节点,这里引入一个新概念:XPath。 在前面的学习中已经知道了XML是一个完整的树形结构文档。在转换XML源文档时,可能需要处理其中的一部分(节点)数据,那么如何查找和定位XML文档中的信息呢?XPath就是一种专门用来在XML文档中查找信息的语言,它是XSLT的重要结成部分。XSL样式表也可以分为三个部分,即:XSLT、XPath和FO。XPath属于XSL,所以通常会将XSL语法和XPath语法混在一起说。用简明的解释:如果将XML文档看作是一个数据库,XPath就像SQL查询语言;如果将XML文档看作DOS目录结构,XPath就像cd、dir等目录操作命令的集合。 要学习XSL,必须先了解和掌握XPath。
XPath节点 在XPath里,有7种不同的节点类型: • 根节点或文档节点(Document Node) • 元素节点(Element Node) • 属性节点(Attribute Node) • 文本节点(Text Node) • 命名空间节点(Namespace Node),可以认为是一种特 • 殊的属性节点 • 处理指令(PI)节点 • 注释节点(Comment Node)
Expression 表达式 Description 注释 nodename 选取某节点中的所有子节点 / 从根节点处选取或选择子元素,返回左侧元素的直接子元素 // 递归下降,不论深度,选取文档中所有匹配的节点,不管该节点位于何处 . 选取当前节点 .. 选取当前节点的父节点 @ 选取属性 XPath语法 1、路径表达式
表达式 结果 /bookstore/book[1] 选取bookstore元素下的第一个book元素 /bookstore/book[last()] 选取bookstore元素下的最后一个book元素 /bookstore/book[last()-1] 选取bookstore元素下的倒数第二个book元素 /bookstore/book[position()<3] 选取bookstore元素下的前两个book子元素 //title[@lang] 选取所含指定的lang属性的有包title元素 //title[@lang='eng'] 选取所有lang属性值为“eng”的所有“title”元素 /bookstore/book[price>35.00] 选取bookstore元素下所有price元素值大于35.00的book元素 /bookstore/book[price>35.00]/title 选取bookstore元素下所有price元素值大于35.00的book节点下的title元素 2、条件测试
通配符 表达式 结果 说明 * //book/title | //book/price 选取book元素中的所有title和price元素 匹配任意的元素节点 //title | //price @* 选取文档中的所有title元素和price元素 匹配任意的属性节点 node() /bookstore/book/title | //price 选取bookstore元素中book元素所对应的所有title元素以及文档中所有的price元素 匹配所有类型的节点 3、通配符 4、多路径选取
方法名称 结果 ancestor 选取当前节点的祖类元素(父类元素,父类元素的父类元素,以此类推) ancestor-or-self 选取当前节点和当前节点的祖类元素(父类元素,父类元素的父类元素,以此类推) attribute 选取当前节点的所有属性 child 选取当前节点的所有子类元素 descendant 选取当前节点的所有孙类元素(子类元素,子类元素的子类元素,以此类推) descendant-or-self 选取当前节点和当前节点的所有孙类(子类元素,子类元素的子类元素,以此类推) following 选取文档中位于当前节点结束标签之后的所有元素 following-sibling 选取位于当前节点后的所有同类节点 namespace 选取当前节点下的所有命名空间节点 parent 选取当前节点的父类节点 preceding 选取文档中所有位于当前节点的起始标签之前的元素 preceding-sibling 选取位于当前节点之前的所有同类节点 self 选取当前节点 坐标轴
操作符 说明 案例 返回值 | 计算两个节点集 //book | //cd 返回所有book元素和cd元素的节点集 + 加 6 + 4 10 - 减 6 - 4 2 * 乘 6 * 4 24 div 除 8 div 4 2 = 等于 price=9.80 如结果为9.80,则返回true;如结果为9.90,则返回false != 不等于 price!=9.80 如结果为9.90,则返回true;如结果为9.80,则返回false < 小于 price<9.80 如结果为9.00,则返回true;如结果为9.80,则返回false <= 小于等于 price<=9.80 如结果为9.00,则返回true;如结果为9.90,则返回false > 大于 price>9.80 如结果为9.90,则返回true;如结果为9.80,则返回false >= 大于等于 price>=9.80 如结果为9.90,则返回true;如结果为9.70,则返回false or 或 price=9.80 or price=9.70 如结果为9.80,则返回true;如结果为9.50,则返回false and 与 price>9.00 and price<9.90 如结果为9.80,则返回true;如结果为8.50,则返回false mod 求模(即:余数) 5 mod 2 1 操作符
常用函数 XPath函数库包括4组共27个函数,分为节点集函数组、布尔函数组、数字函数组和字符函数组。 1、节点集函数组 节点集函数组就是那些传入的参数是节点或节点集的函 数,它们的返回值可以是任何类型。 last():返回当前选中节点集的最后一个节点的位置。值为数字。 position():返回当前正在处理的节点处理选中的节点集的位置。值为数字。常用于判断式,如[position()=2],则返回节点集中的第二个节点。 count(node-set):返回当前选中的节点集的节点数量。 local-name(node-set):返回传入节点的本地部分。 namespace-uri(node-set):返回传入节点的命名空间URI部分。 name(node-set):返回传入节点的完整扩展名称,包括命名空间URI部分。
2、布尔函数组 布尔函数组中的函数要求传入的参数是布尔变量,返回值一般也是布尔值。 boolean(对象):主要用来测试指定的“对象”是否“存在”。如果对象指定的是一个节点集,当且仅当节点集不为空时返回的结果才为真。如果是一个字符串,当且仅当字符串的长度大于0时返回值才为真。如果是一个数字,当且仅当数字大于0才返回真。其他一切情况返回的结果都是假。 not(boolean):返回传入值的相反值,即传入真值时返回假,传入假时返回真。 true():简单的返回true。 false():简单的返回false。 lang(str):返回值为布尔值,根据上下文节点是否有xml:lang属性,且它的值是否等于“str”指定的。如果有且相等,则返回true。
3、数字函数组 数字函数组包括: number(对象):将一个对象转换为数字。 sum(node-set):把传入的节点集中每一个节点转换为数字并求和。 floor(num):提供一个向后的舍入功能。如floor(5.3)返回5;floor(5.8)返回5;floor(-3.3)返回-4。 ceiling(num):寻找最近的一个整数,大于或等于其参数提供的数字。如ceiling(5.3)返回6;ceiling(5.8)返回6;ceiling(-3.3)返回-3。 round(num):返回四舍五入的数字结果。如round(5.3)返回5;round(5.8)返回6;round(-3.3)返回-3。
4、字符串函数组 字符串函数组包括: String():以XPath中的四种类型对象为参数,并将其转换为一个字符串。原型:string string(对象) Concat():传入参数为字符串或表达式,返回由两个或更多字符串组成的字符串。原型:string concat(string,string,…) Substring():返回字符串指定位置的字符串。原型:string substring(string,number,number)。 Contains():用于检查原始的字符串中是否有一个子字符串存在。原型:boolean contains(string,string)。
XSL模板及使用 1、XSL模板定义指令 定义一个XSL模板的语法格式如下: <xsl:template match=”pattern”> <!--输出内容与输出格式定义--> </xsl:template> 2、XSL取值输出指令 其语法是: <xsl:value-of select=”element-name”/> 3、XSL模板调用命令 调用一个指定模板的语法是: <xsl:apply-templates select=”pattern”>
XSL节点的访问 • 使用元素名访问节点 可以在模板规则中直接使用XML源文档的某个元素名来选择相匹配的节点。例如例7.2文档中的代码: <xsl:apply-templates select="联系人列表"/> <xsl:template match="联系人列表"> <xsl:value-of select=“姓名”/> • 使用匹配符访问节点 1、匹配根节点 在XSL中,第一个出现的模板必须是根节点模板。根节点的匹配使用“/”符号,一般情况下,在XSL文档中一定会有这样一句代码: <xsl:template match=”/”>
2、匹配根元素 根元素,就是XML文档中最顶层的元素,根元素的匹配符号为“/*”。如果想与根元素匹配,只需如下例: <xsl:template match=”/*”> 3、匹配当前节点和父节点 当前节点的匹配符是一个圆点“.”,当前节点的父节点的匹配符为两个圆点“..”,非常类似于操作系统中的当前路径和当前路径的上级路径的表示方法。 <xsl:temlate match=”联系人”> <xsl:value-of select=”.”/> <xsl:value-of select=”..”/> </xsl:template>
使用路径访问节点 1、绝对路径与相对路径 绝对路径是从根节点到指定节点的路径;相对路径是从当前节点到指定节点的路径。单独的“/”代表根节点。在路径中使用“/”作为分隔符号。 例: 绝对路径:/联系人列表/联系人/姓名 相对路径:联系人/姓名 2、在match属性中使用路径 可以在match属性中使用路径的方式来选择元素。 如: <xsl:template match=”/联系人列表/联系人/姓名”></xsl:template>这里使用的是绝对路径,从根节点开始查找。
3、在select属性中使用路径 例如,要直接选择“姓名”节点,使用如下模板即可: <xsl:template match=”/”> <xsl:applay-templates select=”联系人列表/联系人/姓名”/> </xsl:template> <xsl:template match=”姓名”> <xsl:value-of select=”.”/><br/> </xsl:template> 4、使用路径通配符 在路径中允许“*”号来代替任意的元素节点名称。如,只知道“联系人列表”的孙子节点“姓名”,而不知道儿子节点的名称,就可以使用“*”号来代替“联系人列表”元素的任意儿子节点,如下所示: <xsl:template match=”/”> <xsl:apply-templates select=”联系人列表/*/姓名”/> </xsl:template>
5、使用“//”符号 星号只能用于匹配已知结构中的某一层的任意元素,而使用“//”可以直接引用任意层的后代节点,如,可以使用下面的模板来获得“姓名”节点的内容: <xsl:template match=”/”> <xsl:applay-templates select=”联系人列表//姓名”/> </xsl:template> <xsl:template match=”姓名”> <xsl:value-of select=”.”/><br/> </xsl:template>
访问指定的元素属性 如果XML源文件中有属性,我们要将它显示出来,就要用到访问元素属性。其语法格式为: @属性名 … <xsl:template match="联系人"> <tr> <td><xsl:value-of select="姓名"/> </td> <td><xsl:value-of select="@ID"/></td> <td><xsl:value-of select="公司"/> </td> <td><xsl:value-of select="EMAIL"/></td> <td><xsl:value-of select="电话"/> </td> <xsl:apply-templates select="地址"/> </tr> </xsl:template> …
在模板中选择多个元素 XSL允许一次选择多个节点,只需要使用“|”来选择模板匹配的多个元素即可。 如,下面的模板应用于“姓名”、“ID”和“公司”: <xsl:template match=”姓名|ID|公司”> <xsl:value-of select=”.”/> </xsl:template> 还可以使用带路径的选择方式,如: <xsl:template match=”联系人/ID | 联系人/姓名 | 联系人/公司”> <xsl:value-of select=”.”/> </xsl:template>
使用附加条件访问节点 1、限制元素必须有子元素 选择具有“公司”子元素的“联系人”元素,可以使用下面的模板: <xsl:template match=”联系人[公司]”> <xsl:value-of select=”姓名”/> </xsl:template> 2、添加多个限制条件 XSL里面可以使用“|”符号来组合多个限制条件,如: <xsl:template match=”联系人[ID|公司]”> <xsl:value-of select=”姓名”/> </xsl:template> 3、在条件中使用星号 使用“*”星号选择符合条件的任意元素,如: <xsl:template match=”*[公司]”> <xsl:value-of select=”姓名”/> </xsl:template>
4、限制于元素必须带有给定属性 在[]中使用@来指定元素带有的属性,如: <xsl:template match=”联系人[@ID]”> <xsl:value-of select=”姓名”/> </xsl:template> 5、限制元素内容为给定字符串 在[]中使用“=”号,判断元素内容是否与给定字符串完全匹配,如: <xsl:template match=”联系人[ID=’008’]”> <xsl:value-of select=”.”/> </xsl:template>
XSL控制指令 • 判断指令 1、以元素名为条件 如,<xsl:if test=”元素名”>则可以将XML元素的名称作为判断的条件。 2、以元素内容为条件 如,<xsl:if test=”元素名[.=’元素内容’]”>则可以以指定的XML元素内容作为判断条件。 下面的例子是输出姓名为“张扬”的两个子元素数据: <xsl:if test=”姓名=’张扬’”> <xsl:value-of select=”ID”/> <xsl:value-of select=”公司”/> </xsl:if> 3、以元素属性为条件 可以使用元素的属性为判断的条件,如: <xsl:if test=”@属性名称=’属性值’”>
多条件判断指令 <xsl:choose> <xsl:when test=”pattern”> <!--处理语句--> </xsl:when> <xsl:when test=”pattern”> <!--处理语句--> </xsl:when> …… <xsl:otherwise test=”pattern”> <!--处理语句--> </xsl:otherwise>
循环处理指令 如果要对XML文档中多个相同节点的数据进行同样的处理和输出,就可以使用循环处理指令<xsl:for-each>。这种循环处理指令能够遍历整个XML文档结构树,其语法结构如下: <xsl:for-each select=”pattern” > <xsl:value-of ……/> …… </xsl:for-each>
输出内容的排序 <xsl:sort>元素作为<xsl:apply-templates>或<xsl:for-each>的子元素出现,可以对输出元素按指定的关键字顺序进行排序。其主要属性有以下几个: Select属性:设置排序的关键字 Order属性:设置排序次序,“ascending”为升序,“descending”为降序。 Data-type属性:设置排序是否按数字或文本进行,“number”为数字,“text”为文本。
小结 • 本章介绍了: • 什么是XSL • 什么是XPath • XPath及其相关技术 • XSL模板及其使用 • XSL节点的选择方法 • XSL控制指令 • XSL的应用
作业 1、简述XSL文档的基本结构。 2、XSL技术与CSS技术有哪些区别?