以下是XPath字符串函数列表 -
序号 | 函数 | 描述 |
---|---|---|
1 | starts-with(string1, string2) |
当第一个字符串(string1 )以第二个字符串(string2 )开头时返回true 。 |
2 | contains(string1, string2) |
当第一个字符串(string1 )包含第二个字符串(string2 )时返回true 。 |
3 | substring(string, offset, length?) |
返回字符串的一部分,该部分从偏移量(offset )开始,直到提供的长度(length )。 |
4 | substring-before(string1, string2) |
返回在第一次出现string2 之前的string1 部分。 |
5 | substring-after(string1, string2) |
返回在第一次出现string2 之后的string1 部分。 |
6 | string-length(string) |
以字符形式返回字符串的长度。 |
7 | normalize-space(string) |
修剪字符串中的前导和尾随空格。 |
8 | translate(string1, string2, string3) |
返回在string1 中,被string2 任何匹配字符替换为string3 中的字符后。 |
9 | concat(string1, string2, ...) |
连接所有字符串(string1 ,string2 ,... )。 |
10 | format-number(number1, string1, string2) |
将string1 应用为格式字符串后,返回number1 的格式化版本。 string2 是可选的区域设置字符串。 |
示例
此示例通过迭代每个学生创建一个<student>
元素的表,其中包含名称和名称长度。 它在连接名字和姓氏后计算学生姓名的长度,然后打印学生的详细信息。
文件:students.xml -
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Su</lastname>
<nickname>MaXX</nickname>
<marks>88</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Lee</lastname>
<nickname>Vicky</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Wong</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
文件:students.xsl -
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/">
<html>
<body>
<h2>Students</h2>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Name</th>
<th>Length of Name</th>
</tr>
<xsl:for-each select = "class/student">
<tr>
<td><xsl:value-of select = "concat(firstname,' ',lastname)"/></td>
<td><xsl:value-of select = "string-length(concat(firstname,' ',lastname))"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
在浏览器中,打开上面示例代码文件:student.xml ,效果如下所示 -