python基础入门之string方法总结

本文最后更新于:December 21, 2020 am

1. Sequence Types

  1. sequence类型有六种:strings、byteobjects、bytearrays、lists、tuples、range objects
  2. sequence类型都支持的通用操作:
  • 成员检查:in、not in
  • 连接:+
  • 复制:*
  • 下标取值:s[i]
  • 切片:s[i: j]
  • 长度检查:len(s)
  • 最小值:min(s)
  • 最大值:max(s)
  • 索引取值:s.index(i)
  • 字符串统计:s.count(i)

2. 判断&删除类方法

A. 判断

1
2
3
4
5
6
7
8
9
10
11
12
13
str.endswith(suffix[,start[,end]]):      判断字符串是否以指定后缀结尾,返回TrueFalse。start和end指定判断的起始范围,默认全字符串。
str.startwith(prefix[, start[,end]]): 判断字符串是否以指定前缀开头,返回TrueFalse。start和end指定判断的起始范围,默认全字符串。
str.islower(): 判断字符串中的字母字符是否全部为小写,该方法仅判断字符串中的字母字符,不理会其它字符。字符串必须至少包含一个字母字符,否则返回False
str.isupper(): 判断字符串中的字母字符是否全部为大写,该方法仅判断字符串中的字母字符,不理会其它字符。字符串必须至少包含一个字母字符,否则返回False
str.istitle(): 判断字符串每个单词(以空格分割)的首字母是否大写。字符串必须至少包含一个字母字符,否则返回False。即使首字母字符前面有非字母字符,如中文、数字、下划线等,也不影响对首字母字符的判断。
str.isalnum(): 判断字符串是否只包含由文字数字式字符,字符串仅包含中文字符合法。若字符串包含空格、下划线、~等非文字数字式字符,均返回False
str.isalpha(): 判断字符串是否只包含文字字符,字符串仅包含中文字符合法。
str.isidentifier(): 判断字符串是否是合法的标识符,实际上这里判断的是变量名是否合法(以字母或下划线开头)。
str.isprintable(): 判断字符串所包含的字符是否全部可打印。字符串包含不可打印字符,如转义字符
str.isspace(): 判断字符串是否仅包含空格或制表符。
str.isdecimal(): 判断字符串是否只包含十进制数字字符,包括多国语言的十进制数字字符表现形式。
str.isdigit(): 判断字符串是否只包含数字,这里的数字包括十进制数字和其它特殊数字(如上标数字等)。
str.isnumeric(): 判断字符串是否只包含数字字符。数字字符范围很大。在判断是否只包含数字中,范围最大。

B. 删除

1
2
3
4
str.lstrip([chars]):                     返回一个去除前导字符的新字符串,chars参数是一个字符串,它包含了所有将要被移除的字符集合。默认为空格。从原字符串的最左边开始,匹配chars里包含的所有字符,直至遇到第一个非chars字符为止,原字符串中匹配到的所有字符都被移除。
str.rstrip([chars]): 与str.lstrip()相反,从最右边开始匹配。
str.strip([chars]): 从字符串的两头开始匹配。
str.zfill(width): 返回一个长度为width的数字字符串,最左边填充0。如果width小于等于原字符串长度,则返回原字符串。主要用于数字类字符串的格式化。

3. 变换&对齐类方法

A. 变换

1
2
3
4
5
6
str.encode(encoding=”utf-8”, errors=”strict”):格式化类方法,返回一个格式化的新字符串:
str.lower(): 把全部字母字符转换成小写,不去管其它非字母字符。并返回原字符串
str.upper(): 把全部字母字符转换成大写。不去管其它非字母字符。并返回原字符串
str.swapcase(): 把字符串中的大小写字母互换,大写转换成小写,小写转换成大写。不去管非字母类字符。
str.capitalize(): 字符串首字母大写,其余小写。如果字符串首字符为非字母字符,将不变。
str.title(): 字符串中每个单词的首字母大写,其余小写。单词的首字符为非字母字符也转换。

B. 对齐

1
2
3
str.center(width[,fillchar]):                 返回一个原字符串居中,长度为width的新字符串,width要大于len(str),否则返回原字符串,原字符串开头和结尾处使用fillchar进行填充(优先前面),默认为空格。'abcd'.center(8)或'abcd'.center(8, *)
str.ljust(width[,fillchar]): 返回一个长度为width,左对齐的字符串,最右边填充fillchar,默认为空格。width要大于len(str),否则返回原字符串。
str.rjust(width[,fillchar]): 返回一个长度为width,右对齐的字符串,最左边填充fillchar,默认为空格。width要大于len(str),否则返回原字符串。

4. 查找 & 替换类方法

A. 查找

1
2
3
4
5
str.count(sub[,start[,end]]):                 统计某个字符中子字符串sub的个数。start和end指定统计范围,未指定则默认全字符串范围内统计。
str.find(sub[,start[,end]]): 查找子字符串在字符串中出现的第一个位置,start和end指定一个查找范围。未找到返回-1。如果仅想判断子字符串是否在某一字符串中,用in判断符即可,无需find。
str.rfind(sub[,start[,end]]): 跟find方法一样,返回指定子串的index位置,只不过rfind从字符串的最右边开始查找,找不到时返回-1。注意:从最右边开始查找,但index位置却是从原字符串的最左边开始算的。
str.index(sub[,start[,end]]): 类似str.find(),但是如果没有找到子串,返回raised ValueError。
str.rindex(sub[, start[, end]]): 类似于str.rfind(),但是如果没有找到,返回raises ValueError。

B. 替换

1
2
3
str.replace(old,new[,count]):                 返回一个新字符串,原串中的old被替换为new,country指定替换次数。'AAABBBCCC'.replace('A', 'D', 2)   -->DDABBBCCC
str.format(*args,**kwargs): 调用fortmat方法的字符串中不但有纯文本,也有使用{}界定符包括起来的替换字段。替换字段既可以是位置参数的数值索引,也可以是字典或属性的Key值。该方法返回的字符串里,所有替换字段都被相应参数的值所替代。如:‘UserID: {UID} Last login:{last_login}'.format(UID = ‘root',last_login= ‘5Mar 2012') -->User ID:root Last login: 5Mar2012
str.expandtabs([tabsize]): 把字符串中的所有制表符替换成零个或多个空格,每个制表符替换成多少个空格,由制表符在字符串中的位置和tabsize共同决定。tabsize指定每个制表符替换成的空格数,默认为8个

5. 拆分 & 组合类方法

A. 拆分

1
2
3
4
5
str.partition(sep):                           该方法用于拆分字符串,返回一个包含三个元素的元组。如果未能在原字符串中找到Sep,则元组的三个元素为:原字符串,空串,空串;否则,从原字符串中遇到的第一个Sep字符开始拆分,元组的三个元素为:Sep之前的字符串,Sep字符,Sep之后的字符串
str.rpartition(sep): 与str.partition()相反,从原字符串的最右边开始拆分,但是同样返回包含三个元素的元组:倒数第一个Sep之前的字符串,Sep字符,Sep之后的字符串。
str.split([sep[,maxsplit]]): 返回一个以Sep分隔的列表,maxsplit指定拆分次数(因此,列表中元素的个数为maxsplit + 1)。Sep默认为空格,maxsplit默认不限制拆分次数。如果未指定Sep或指定Sep为None''),str两端的空格将舍弃;如果指定Sep(不管能否在原字符串中找到Sep),str两端的空格将保留
str.rsplit([sep[,maxsplit]]): 与str.split()类似,只是它从最右边开始拆分。只有在指定maxsplit的情况下才会看到效果。
str.splitlines([keepends]): 拆分一个包含多行的字符串,以每行为一个元素返回一个列表。如果字符串不是多行的,则返回原字符串。keepends是一个True字符或非零整数,表示保留行尾标志。该方法多用于处理文件。Line.splitlines(True) -->['AB\n','CD\n', 'EF']

B. 组合

1
str.join(iterable):                           使用连接符str来连接iterable对象中的元素,返回一个被str连接起来的,由iterable对象的元素组成的字符串。如果传入一个非iterable对象,如整数、布尔值等,将返回Type Error。sequencetype(六种:strings、byteobjects、bytearrays、lists、tuples、rangeobjects)和dictionary都属于iterable对象。