本文是转载的,原文网址:http://www.cnblogs.com/zhaozhan/archive/2010/01/17/1650242.html

字符串函数主要用来处理字符串。字符串函数主要包括以下:concat(),contains(),normalize-space(),substing(),substring-before(),subsring-after(),translate().

1、concat()

concat()函数用于串连多个字符串。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <root>
    <e id="1">st</e>
    <e id="2">nd</e>
    <e id="3">rd</e>
    </root>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="text" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/root">
    <xsl:for-each select="e">
    <xsl:value-of select="concat(@id,.,' ')"/>
    </xsl:for-each>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. 1st
    2nd
    3rd

2、contains()

contains(str1,str2)函数用来判断str2是否是第一个字符串的一部分。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <books>
    <book>XML</book>
    <book>XSLT</book>
    <book>XPath</book>
    <book>C#</book>
    </books>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="xml" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/books">
    <books>
    <xsl:for-each select="book">
    <xsl:if test="contains(.,'X')">
    <xsl:copy>
    <xsl:value-of select="."/>
    </xsl:copy>
    </xsl:if>
    </xsl:for-each>
    </books>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. <?xml version="1.0" encoding="gb2312"?>
  2. <books>
  3.     <book>XML</book>
    <book>XSLT</book>
    <book>XPath</book>
    </books>

3、normalize-space()

normalize-space()用来将一个字符串的头部和尾部的空白字符删除,如果字符串中间含有多个连续的空白字符,将用一个空格来代替。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <article>
    <title> When The Wind Blows</title>
    <paragraph>
    When you have get ready for everything ,you could
    Sleep though the wind blows
    </paragraph>
    <paragraph>
    That means you should do your best on your work and fear
    nothing
    </paragraph>
    </article>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="xml" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/books">
    <xsl:apply-templates select="article"/>
    </xsl:template>
    <xsl:template match="article">
    <xsl:copy>
    <xsl:apply-templates select="*"/>
    </xsl:copy>
    </xsl:template>
    <xsl:template match="*">
    <xsl:copy>
    <xsl:value-of select="normalize-space()"/>
    </xsl:copy>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. <?xml version="1.0" encoding="gb2312"?>
    <article>
    <title>When The Wind Blows</title>
    <paragraph>When you have get ready for everything ,you could Sleep though the wind blows</paragraph>
    <paragraph>That means you should do your best on your work and fear nothing</paragraph>
    </article>

4、starts-with()

start-with(string,startr)函数用来判断string是否以startstr开头。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <books>
    <book>XML</book>
    <book>XSLT</book>
    <book>XPath</book>
    <book>C#</book>
    </books>

xslt:

显示行号 复制代码 ?
  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="xml" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/books">
    <xsl:copy>
    <xsl:for-each select="book">
    <xsl:if test="starts-with(.,'X')">
    <xsl:copy-of select="."/>
    </xsl:if>
    </xsl:for-each>
    </xsl:copy>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. <?xml version="1.0" encoding="gb2312"?>
  2. <books>
  3.     <book>XML</book>
    <book>XSLT</book>
    <book>XPath</book>
    </books>

5、string-length()

string-length(string)函数用来返回参数string的长度,如果参数string为缺省,将返回上下文节点的字符串长度。

6、substring()

substring(string,number,length)函数用来截取字符串。参数string用于指定要截取的字符串;参数number用于指定开始位置;参数length用于指定截取字符串的长度。如果缺少length参数将从开始位置number一直到截取字符串的长度

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <root>
    <text>123456789ABCDEF</text>
    </root>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="text" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/root">
    <xsl:value-of select="substring(text,1,5)"/>
    <xsl:text> </xsl:text>
    <xsl:value-of select="substring(text,1)"/>
    <xsl:text> </xsl:text>
    <xsl:value-of select="substring(text,1,string-length(text))"/>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. 12345
    123456789ABCDEF
    123456789ABCDEF

7、substring-before()

substring-before(str1,str2)函数用于返回字符串str1中位于字符串str2之前的部分。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <datetime>
    <date>2010-01-17</date>
    <time>22:49:30</time>
    </datetime>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="text" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/datetime">
    <xsl:apply-templates select="*"/>
    </xsl:template>
    <xsl:template match="date">
    <xsl:value-of select="concat(substring-before(.,'-'),'年')"/>
    </xsl:template>
    <xsl:template match="time">
    <xsl:value-of select="concat(substring-before(.,':'),'时')"/>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. 2010年22时

8、substring-after()

substring-after(str1,str2)函数跟substring-before类似,substring-after0返回字符串str1中位于字符串str2之后的部分。

简单示例:

xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <dir>
    <file>a.txt</file>
    <file>t.xml</file>
    <file>t.xslt</file>
    </dir>

xslt:

  1. <?xml version="1.0" encoding="UTF-8"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="xml" version="1.0" encoding="gb2312" indent="yes"/>
    <xsl:template match="/dir">
    <extends>
    <xsl:for-each select="file">
    <extend>
    <xsl:value-of select="substring-after(.,'.')"/>
    </extend>
    </xsl:for-each>
    </extends>
    </xsl:template>
    </xsl:stylesheet>

结果:

  1. <?xml version="1.0" encoding="gb2312"?>
    <extends>
    <extend>txt</extend>
    <extend>xml</extend>
    <extend>xslt</extend>
    </extends>

9、translate()

translate(string,replaced_txt,replacement_txt)函数用来替换字符串,替换string中的所有replaced_txt为replacement_txt.

XPath函数——字符串函数(转载)的更多相关文章

  1. ylb:SQLServer常用系统函数-字符串函数、配置函数、系统统计函数

    原文:ylb:SQLServer常用系统函数-字符串函数.配置函数.系统统计函数 ylbtech-SQL Server:SQL Server-SQLServer常用系统函数 -- ========== ...

  2. javascript函数一共可分为五类: ·常规函数 ·数组函数 ·日期函数 ·数学函数 ·字符串函数

    javascript函数一共可分为五类:    ·常规函数    ·数组函数    ·日期函数    ·数学函数    ·字符串函数    1.常规函数    javascript常规函数包括以下9个 ...

  3. Sass函数--字符串函数

    Sass的函数简介在 Sass 中除了可以定义变量,具有 @extend.%placeholder 和 mixins 等特性之外,还自备了一系列的函数功能.其主要包括: ● 字符串函数 ● 数字函数 ...

  4. mssql 系统函数-字符串函数专题--字符串函数大全

    mssql 系统函数 字符串函数 substring 功能简介 mssql 系统函数 字符串函数 stuff 功能简介 mssql 系统函数 字符串函数 str 功能简介 mssql 系统函数 字符串 ...

  5. php常用函数——字符串函数

    php常用函数——字符串函数

  6. 2016/3/17 Mysq select 数学函数 字符串函数 时间函数 系统信息函数 加密函数

    一,数学函数主要用于处理数字,包括整型.浮点数等. ABS(X) 返回x的绝对值 SELECT ABS(-1)--返回1 CEll(X),CEILING(x)  返回大于或等于x的最小整数 SELEC ...

  7. Linux下常用函数-字符串函数

    inux下常用函数-字符串函数 atof(将字符串转换成浮点型数)  相关函数   atoi,atol,strtod,strtol,strtoul 表头文件   #include <stdlib ...

  8. sql server 系统常用函数:聚合函数 数学函数 字符串函数 日期和时间函数和自定义函数

    一.系统函数 1.聚合函数 聚合函数常用于GROUP BY子句,在SQL Server 2008提供的所有聚合函数中,除了COUNT函数以外,聚合函数都会忽略空值AVG.COUNT.COUNT_BIG ...

  9. sqlserver 中常见的函数字符串函数

    ---字符中操作函数 UPPER(S) 将字符串统一为大写字母 SELECT UPPER('asasA') --ASASA LOWER(S) 将字符串统一为小写字母 SELECT LOWER('asa ...

随机推荐

  1. YourSQLDba备份失败案例锦集

    使用YourSQLDba做备份.维护.管理时,偶尔会收到一些备份失败的邮件.导致YourSQLDba备份失败的情况比价多,打算在此篇中对YourSQLDba备份失败的案例做一些总结.整理. 1:You ...

  2. [20141121]无法通过powershell读取sql server性能计数器问题

    背景: 全新服务器,需要增加性能监控,发现无法通过powershell读取性能指标 解决方法: Open the Registry Editor by going to the Start Menu ...

  3. 为什么基于TCP UDP服务的一些简单服务端口号都是奇数

    TCP是有NCP(网络控制协议)派生出来的,NCP是单工的,通信需要两个链接,所以会预留奇偶端口号.当TCP/UDP成为传输层协议,每个程序只是用一个端口号,且使用奇端口号.

  4. 0025 Java学习笔记-面向对象-final修饰符、不可变类

    final关键字可以用于何处 修饰类:该类不可被继承 修饰变量:该变量一经初始化就不能被重新赋值,即使该值跟初始化的值相同或者指向同一个对象,也不可以 类变量: 实例变量: 形参: 注意可以修饰形参 ...

  5. Linux – Usermod命令参数解析和实例说明

    usermod 命令修改系统帐户文件来反映通过命令行指定的变化 1. 首先看看usermod都是有哪些参数 [root@hxweb101 ~]$ usermod --help Usage: userm ...

  6. CentOS 7 恢复 Windows 启动项

    安装Linux时一般会自动识别windows系统并添加引导项,而 CentOS 默认不支持 NTFS 分区,CentOS7采用了Grub2,与CentOS6有区别.手动引导windows分区修改配置稍 ...

  7. FineReport实现根据点击次数奇偶性排序的方法

    使用FineReport报表软在进行排序的时,很多时候您可能想实现根据点击的次数进行升降序排序,也就是说点击第一次点击标题升序排序,再次点击就降序,以此类推,而不是通过选择升序进行升序排列,选择降序进 ...

  8. Leetcode: word search

    July 6, 2015 Problem statement: Word Search Given a 2D board and a word, find if the word exists in ...

  9. python 聊天室

    server端程序 # -*- coding: utf-8 -*- #!/usr/bin/python """ """ import soc ...

  10. VR(虚拟现实)开发资源汇总

    Daydream https://developers.google.cn googlevr Google VR for Android GVR SDK and NDK Release Notes c ...