本文共 1575 字,大约阅读时间需要 5 分钟。
字符串是7种序列类型中的一种。
除了序列的操作函数,比如len()来求字符串长度之外,Python还为字符串提供丰富到可以写个编辑器的API.首先,下面的查找API都是为了查找位置,或者查一共有几次这样的操作。
如果只是想判断一个字符串是不是另一个字符串的子串的话,使用序列的in运算符就可以了。例:str1 = "hahahahaha,heiheihei" if 'haha' in str1: print('haha is a substring of '+str1)else: print('haha is NOT a substring of '+str1)
原型:str.count(sub[, start[, end]])
字符串的count函数可以数出来有多少次匹配,我们看个例子,有5个ha和3个hei
str1 = "hahahahaha,heiheihei"print(str1.count('ha'))print(str1.count('haha'))
输出为5和2.
haha只能匹配两次。再加上扩展参数:
print(str1.count('ha',1))print(str1.count('ha',0,5))
find函数的行为是,如果能找到,则返回在序列中的坐标,如果找不到,则返回-1. rfind是从右向左查找。我们来看例子:
print(str1.find('haha'))print(str1.rfind('haha'))
输出值为0和6.
找不到的例子:
print(str1.find('hoho'))print(str1.rfind('hi'))
输出值都是-1.
完整形式:
index和rindex的功能与find和rfind基本上一致,除了在找不到时会抛出ValueError异常而不是返回-1.
例:
>>> str1 = "hehe">>> str1.index('ha')Traceback (most recent call last): File "", line 1, in ValueError: substring not found
所以我们需要加try...except语句来处理之:
try: str1.index('hoho')except ValueError: print('hoho cannot be found in '+str1)
有时候,我们希望做从头匹配或者匹配尾部。这时候就要用到startswith函数和endswith函数。例:
print(str1.startswith('ha'))print(str1.endswith('hei'))
这两个返回值均为True.
如果需要更复杂的匹配,还是需要正则表达式。与Java等语言不同,Python中的正则表达式有专门的模块,字符串的API不负责这个事情。
转载地址:http://rpisa.baihongyu.com/