第6章 字符串
一、字符串索引
1、假设有字符串s=”apple”,那么可以通过索引去访问其中的字符,Python通过方括号来标识字符串索引,索引从0开始:s[0]=”a”,s[1]=”p”,s[2]=”p”,s[3]=”l”,s[4]=”e”。
2、python也支持使用负数索引,比如如果要访问字符串s的最后一个字符,那么按照正索引则可以通过s[len(s)-1]访问,也可以通过s[-1]来访问最后一个字符,这就是负数索引,从字符串最后一位到第一位对应的索引数字为-1,-2…,-[len(s)]。
3、使用for循环访问字符串中的字符
下例程序计算给定字符串的字符编码总和:
#codesum.py def codesum1(s): """Returns the sums of the character codes of s. """ total=0 for c in s: total=total+ord(c) return total myinput=input("please input a string:") print("你输入字符串的字符编码和为:"+str(codesum1(myinput)))
上述代码中直接通过”for c in s”来进行索引,每次c迭代为s中的字符,表达式简洁明了,ord()函数功能是返回字符的编码数值。
如果使用正索引则如下,表达方面相对显得更复杂:
#codesum1.py def codesum1(s): """Returns the sums of the character codes of s. """ total=0 for i in range(len(s)): total=total+ord(s[i]) return total myinput=input("please input a string:") print("你输入字符串的字符编码和为:"+str(codesum1(myinput)))
二、字符
1、之前提到函数ord()可以获得字符对应的编码值,如ord(“a”),为97。同样,给定字符编码,也可以获得其对应的字符,如chr(97),为“a”。
2、转义字符:一般常用的转义字符:
对应反斜杠
’对应单引号
”对应双引号
对应换行符
对应回车
对应水平制表符
如>>>print(“”and’ are quotes”)
输出为:”and’ are quotes
print(“ must be written \”) 输出为: must be written
三、字符串切片
对于从字符串中提取子串可通过切片来操作,指定要提取子串第一个字符的索引号,以及子串最后一个字符的索引号加1。
如>>>food=’apple pie’
food[0:5] 输出为:apple food[6:9] 输出为:pie 如果省略切片起始索引,将默认为0;如果省略切片的终止索引,将默认为至最后一个字符。 如>>>food=’apple pie’ food[:5] 输出为:apple food[6:] 输出为:pie food[:] 输出为:apple pie。 示例:返回一个文件名中的扩展名
def get_ext(fname): i=0 for c in fname: if c=='.': break i+=1 return fname[i+1:] fn=input("please input a filename:") print("你输入文件名的后缀为:"+get_ext(fn))
也可以利用rfind函数:
def get_ext(fname): #从右边开始查找字符"." dot=fname.rfind(".") #没有找到 if dot==-1: return "" else: return fname[dot+1:] fn=input("please input a filename:") print("你输入文件名的后缀为:"+get_ext(fn))
四、标准字符串函数
1、测试函数
主要包括:
s.endswith(t):是否以t结尾
s.startswith(t):是否以t开头
s.isalnum():是否只包涵字母或数字
s.isalpha():是否只包含字母
s.islower():是否只包含小写字母
s.isupper():是否只包含大写字母
t in s:s是否包含字符串t
2、搜索函数
主要包括:
s.find(t):如果没有找到子串t,则返回-1;否则返回t在s中的起始位置
s.rfind(t):与find相同,但从右重点内容往左搜索
s.index(t):与find相同,但如果找不到t则引发一个异常
s.rindex(t):与index相同,但从右往左搜索
3、改变大小写的函数
s.capitalize():将s[0]改为大写
s.lower():将s所有字母都小写
s.upper():将s所有字母都大写
s.swapcase():将s中字母大小写互换
上述返回字符串
4、设置格式的函数
s.center(n,ch):包含n个字符的字符串,其中s位于中央,两边用字符ch填充
s.ljust(n,ch):包含n个字符的字符串,其中s位于左边,右边用字符ch填充
s.rjust(n,ch):包含n个字符的字符串,其中s位于右边,左边用字符ch填充
上述返回字符串
5、剥除函数
s.strip(ch):从s开头和末尾删除所有包含在字符串ch中的字符
s.lstrip(ch):从s开头删除所有包含在字符串ch中的字符
s.rstrip(ch):从s末尾删除所有包含在字符串ch中的字符
上述返回字符串
6、拆分函数
s.partition(t):将s拆分为三个字符串head、t、tail。head为t前面的子串,tail为t后面的子串。
s.rpartition(t):与partition相同,但从s右边开始搜索t
s.split(t):以t为分隔符,将s划分成一系列的子串,并返回一个由这些子串组成的列表
s.rsplit(t):与split相同,但从右边开始搜索t
s.splitlines():返回一个由s中各行组成的列表
7、替换函数
s.replace(old,new):将s中的每个old替换为new
s.expandtabs(n):将s中的每个制表符替换为n个空格
上述返回字符串
8、其他函数
s.count(t):返回t在s中出现的次数
s.encode():设置s的编码
s.join(seq):使用s将seq中字符串连接成一个字符串
s.zfill(width):在s左边添加足够多的0使得字符串长度为width
五、正则表达式
一些简单的正则表达式运算符
xy?:可描述x和xy(?表示其左边的字符是可选可不选的)
x|y:可描述x和y
x*:可描述由0或更多个x组成的字符串
x+:可描述至少由1个x组成的字符串
正则表达式中可使用圆括号指出将运算符用于哪个子串。如:
(ha)+!:表示ha!,haha!,hahaha!…
ha+!:表示ha!,haa!,haaa!…
1、使用正则表达式匹配字符串
对于程序如下:
def is_done1(s): return s=='done' or s=='quit' #使用正则表达式 import re #导入正则表达式库 def is_done2(s): return re.match('done|quit',s)!=None
函数re.match(regex,s)表示当regex与s不匹配时返回None,否则返回一个特殊的正则表达式匹配对象。针对上例,如果s不为’done’或’quit’中之一,则re.match()返回None。
如果要识别一个:开头为一个或多个’ha’,末尾为一个或多个‘!’,的字符串。则可以通过正则表达式匹配更容易:
import re def is_funny(s): return re.match('(ha)+!+',s)!=None