Python 的字符串常用内建函数如下:
1.capitalize()
功能:将字符串的第一个字符转换为大写
例:
str1 = 'gary is a good man!'
str2 = str1.capitalize()
print(str2)
Gary is a good man!
2.center(width, fillchar)
功能:返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。
例:
str1 = 'Gary is a good man!'
str2 = str1.center(30,'*')
print(str2)
*****Gary is a good man!******
3.count(str)
功能:返回 str 在 string 里面出现的次数
例:
str1 = 'Gary is a good man!'
str2 = str1.count('o')
print('count for o:', str2)
count for o: 2
4.bytes.decode(encoding="utf-8", errors="strict")
功能:Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。
例:
str1 = 'Gary is a good man!'
str2 = str1.encode('o')
print(str2)
b'Gary is a good man!'
5.encode(encoding='UTF-8',errors='strict')
功能:以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
s = "Gary is a good man!"
s_utf8 = s.encode("UTF-8")
s_gbk = s.encode("GBK")
print(s)
print("UTF-8 编码:", s_utf8)
print("GBK 编码:", s_gbk)
print("UTF-8 解码:", s_utf8.decode('UTF-8', 'strict'))
print("GBK 解码:", s_gbk.decode('GBK', 'strict'))
Gary is a good man!
UTF-8 编码: b'Gary is a good man!'
GBK 编码: b'Gary is a good man!'
UTF-8 解码: Gary is a good man!
GBK 解码: Gary is a good man!
6.endswith(suffix)
功能:检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
例:
str1 = 'Gary is a good man!'
str2 = str1.endswith('o')
print(str2)
False
例:
str1 = 'Gary is a good man!'
str2 = str1.endswith('!')
print(str2)
True
7.expandtabs(tabsize=8)
功能:把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。
例:
str1 = 'Gary is a\t good man!'
str2 = str1.expandtabs()
print(str2)
输出:Gary is a good man!
8.find(str, beg=0 end=len(string))
功能:检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1
例:
str1 = 'Gary is a good man!'
str2 = 'is'
print(str1.find(str2))
5
例:
str1 = 'Gary is a good man!'
str2 = 'hi'
print(str1.find(str2))
-1
9.index(str, beg=0, end=len(string))
功能:跟find()方法一样,只不过如果str不在字符串中会报一个异常.
例:
str1 = 'Gary is a good man!'
print(str1.index('a'))
-1
10.isalnum()
功能:如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False
str1 = "Gary1is2a3good4man"
print(str1.isalnum())
True
str1 = "Gary1is2a3good4man!"
print(str1.isalnum())
False
11.isalpha()
功能:如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False
str1 = "Garyisagoodman"
print(str1.isalpha())
True
str1 = "Tom is a good man!"
print(str1.isalpha())
False
12.isdigit()
功能:如果字符串只包含数字则返回 True 否则返回 False..
str1 = "19801457091"
print(str1.isdigit())
True
str1 = "19801457091yy"
print(str1.isdigit())
False
13.islower()
功能:如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
str1 = "yy19801457091"
print(str1.islower())
True
str1 = "Yy19801457091"
print(str1.islower())
False
14.isnumeric()
功能:如果字符串中只包含数字字符,则返回 True,否则返回 False(中文数字也可以)
str1 = "幺玖萬19801457091零"
print(str1.isnumeric())
True
str1 = "幺玖萬19801457091零RMB"
print(str1.isnumeric())
False
15.isspace()
功能:如果字符串中只包含空白,则返回 True,否则返回 False.
str1 = " "
print(str1.isspace())
True
str1 = "Tom is a good man!"
print(str1.isspace())
False
16.istitle()
功能:如果字符串是标题化的(见 title())则返回 True,否则返回 False
str1 = "Gary Is A Good Man!"
print(str1.istitle())
True
str1 = "Tom Is a Good Man!"
print(str1.istitle())
False
17.isupper()
功能:如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
str1 = "TOM79"
print(str1.isupper())
True
str1 = "Tom79"
print(str1.isupper())
False
18.join(seq)
功能:以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
str1 = "@"
str2 = "Gary is a good man!"
print(str1.join(str2))
G@a@r@y@ @i@s@ @a@ @g@o@o@d@ @m@a@n@!
19.len(string)
功能:返回字符串长度
str1 = "Gary is a good man!"
print(len(str2))
19
20.ljust(width[, fillchar])
功能:返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。
例:
str1 = 'Gary is a good man!'
str2 = str1.ljust(30,'*')
print(str2)
Gary is a good man!***********
21.lower()
功能:转换字符串中所有大写字符为小写.
str1 = "Gary Is A Good Man!"
print(str1.lower())
gary is a good man!
22.lstrip()
功能:截掉字符串左边的空格或指定字符。
str1 = " Gary is a good man!"
print(str1.lstrip())
Gary is a good man!
str1 = "****Gary is a good man!"
print(str1.lstrip('*'))
Gary is a good man!
23.maketrans()
功能:创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
intab = "aon"
outtab = "123"
deltab = "rd"
trantab1 = str.maketrans(intab, outtab)
trantab2 = str.maketrans(intab, outtab,deltab)
print(trantab1)
print(trantab2)
{97: 49, 111: 50, 110: 51}
{97: 49, 111: 50, 110: 51, 114: None, 100: None}
24.max(str)
功能:返回字符串 str 中最大的字母。
str1 = "Gary is a good man!"
print(max(str1))
y
25.min(str)
功能:返回字符串 str 中最小的字母。
str1 = "Gary"
print(max(str1))
G
26.replace(old, new [, max])
功能:把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。
str1 = "Gary is a good good man!"
print(str1.replace('good', 'handsome',1))
Gary is a handsome good man!
27.rfind(str, beg=0,end=len(string))
功能:类似于 find()函数,不过是从右边开始查找.
str1 = "Gary is a good man!"
print(str1.rfind('g', 2, 15))
10
28.rindex( str, beg=0, end=len(string))
功能:类似于 index(),不过是从右边开始.
str1 = "Gary is a good man!"
print(str1.rindex('m', 2, 18))
15
29.rjust(width,[, fillchar])
功能:返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串
例:
str1 = 'Gary is a good man!'
str2 = str1.rjust(30,'*')
print(str2)
***********Gary is a good man!
30.rstrip()
功能:删除字符串字符串末尾的空格.
str1 = "Gary is a good man! "
print(str1.rstrip())
Gary is a good man!
31.split(str="", num=string.count(str))|num=string.count(str))
功能:以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num 个子字符串
str1 = "Gary*is*a*good*man!"
print(str1.split("*"))
['Gary', 'is', 'a', 'good', 'man!']
str1 = "Gary*is*a*good*man!"
print(str1.split("*",2))
['Gary', 'is', 'agoodman!']
32.splitlines([keepends])
功能:按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
str1 = "Gary\nis a\rgood man!"
print(str1.splitlines())
['Gary', 'is a', 'good man!']
33.startswith(str, beg=0,end=len(string))
功能:检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。
str1 = "Gary is a good man!"
print(str1.startswith("r", 2, 8))
True
str1 = "Gary is a good man!"
print(str1.startswith("a"))
False
34.strip([chars])
在字符串上执行 lstrip()和 rstrip()
str1 = "***Gary is a good man!&***"
print(str1.strip("*"))
Gary is a good man!&
35.swapcase()
功能:将字符串中大写转换为小写,小写转换为大写
str1 = "gARY iS A gOOD mAN!"
print(str1.swapcase())
Gary Is a Good Man!
36.title()
功能:返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
str1 = "gary is a good man!"
print(str1.title())
Gary Is A Good Man!
37.translate(table, deletechars="")
功能:根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中
intab = "aon"
outtab = "123"
deltab = "rd"
trantab2 = str.maketrans(intab, outtab, deltab)
str1 = "Gary is a good man!"
print(str1.translate(trantab2))
G1y is 1 g22 m13!
38.upper()
功能:转换字符串中的小写字母为大写
str1 = "gary is a good man!"
print(str1.upper())
GARY IS A GOOD MAN!
39.zfill (width)
功能:返回长度为 width 的字符串,原字符串右对齐,前面填充0
str1 = "Gary is a good man!"
print(str1.zfill(30))
00000000000Gary is a good man!
40.isdecimal()
功能:检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。
str1 = "234234059"
print(str1.isdecimal())
True
str1 = "G234234059"
print(str1.isdecimal())
False