字符传常用功能

方法
描述

string.capitalize

把字符串的第一个字符大写

用法:

name = 'fenggongzi'
print (name.capitalize())

Fenggongzi

string.center(width)

返回一个原字符串居中,并使用空格填充至长度 width 的新字符串

用法:

name = 'fenggongzi'
print (name.center(50,'#'))####################fenggongzi####################

string.count(str,beg=0,end=len(string))

返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数

用法:

name = 'fenggongzi'
print (name.count('g'))
print (name.count('g',0,5))

3
2

 

string.encode(encoding=’UTF-8"’,error=’strict’)

以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'

用法:

name = 'fenggongzi'
print (name.encode('gbk'))b'fenggongzi'

string.endswith(obj, beg=0, end=len(string))

检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.

用法:

name = 'fenggongzi'
print (name.endswith('i'))
print (name.endswith('i',0,5))

True
False

string.expandtabs(tabsize=8)

把字符串 string 中的 tab 符号转为空格,默认的空格数 tabsize 是 8.

用法:

name = 'feng\tgongzi'
print (name.expandtabs(20))feng                gongzi

string.find(str, beg=0, end=len(string))

检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1

用法:

name = 'fenggongzi'
print (name.find('f'))
print (name.find('f',4,6))

0
-1

string.index(str, beg=0, end=len(string))

跟find()方法一样,只不过如果str不在 string中会报一个异常.

用法:

name = 'fenggongzi'
print (name.index('f'))
print (name.index('f',0,6))

0
0

string.isalnum()

如果 string 至少有一个字符并且所有字符都是字母或数字则返

回 True,否则返回 False

用法:

name = 'fenggongzi'
print (name.isalnum())True

string.isalpha()

如果 string 至少有一个字符并且所有字符都是字母则返回 True,

否则返回 False

用法:

name = 'fenggongzi'
name1 = 'fengyang1'
print (name.isalpha())
print (name1.isalpha())

True
False

 

string.islower()

如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False

用法:

name = 'Fenggongzi'
name1 = 'fenggongzi'
print (name.islower())
print (name1.islower())

False
True

string.isnumeric()

如果 string 中只包含数字字符,则返回 True,否则返回 False

用法:

name = '123456'
name1 = 'fenggongzi1'
print (name.isnumeric())
print (name1.isnumeric())

True
False

string.isspace()

如果 string 中只包含空格,则返回 True,否则返回 False.

用法:

name = ' '
name1 = 'feng gong zi'
print (name.isspace())
print (name1.isspace())

True
False

string.istitle()

如果 string 是标题化的(见 title())则返回 True,否则返回 False

用法:

name = 'Feng Gong Zi'
name1 = 'feng gong zi'
print (name.istitle())
print (name1.istitle())

True
False

string.isupper()

如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False

用法:

name = 'FENGGONGZI'
name1 = 'Fenggongzi'
print (name.isupper())
print (name1.isupper())

True
False

string.join(seq)

Merges (concatenates)以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串

用法:

str = '-'
sep = 'abc'
print (str.join(sep))a-b-c

string.ljust(width)

返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串

用法:

name = 'fenggongzi'
print (name.ljust(40,'@'))fenggongzi@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@

string.lower()

转换 string 中所有大写字符为小写.

用法:

name = 'FENGGONGZI'
print (name.lower())

fenggongzi

string.lstrip()

截掉 string 左边的空格

用法:

name = ' FENGGONGZI'
print (name.lstrip())FENGGONGZI

 

string.partition(str)

有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string.

用法:

name = 'fenggongzi'
print (name.partition('f'))('', 'f', 'enggongzi')

string.replace(str1, str2,  num=string.count(str1))

把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次.

用法:

name = 'fenggongzi'
print (name.replace('f','T'))Tenggongzi

string.rfind(str, beg=0,end=len(string) )

类似于 find()函数,不过是从右边开始查找.

用法:

name = 'fenggongzi'
print (name.rfind('f'))0

string.rindex( str, beg=0,end=len(string))

类似于 index(),不过是从右边开始.

用法:

name = 'fenggongzi'
print (name.rindex('f'))

0

string.rjust(width)

返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串

用法:

name = 'fenggongzi'
print (name.rjust(40,'@'))@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@fenggongzi

string.rpartition(str)

类似于 partition()函数,不过是从右边开始查找.

用法:

name = 'fenggongzi'
print (name.rpartition('f'))('', 'f', 'enggongzi')

string.rstrip()

删除 string 字符串末尾的空格.

用法:

name = 'fenggongzi '
print (name.rstrip())

fenggongzi

string.split(str="", num=string.count(str))

以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串

用法:

name = 'fenggongzi '
print (name.split('g'))print (name.split('g',2))

['fen', '', 'on', 'zi          ']

['fen', '', 'ongzi          ']

string.splitlines(num=string.count('\n'))

按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行.

用法:

name = 'feng\ngong\nzi'
print (name.splitlines())['feng', 'gong', 'zi']

string.startswith(obj, beg=0,end=len(string))

检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查.

用法:

name = 'fenggongzi'
print (name.startswith('f'))
print (name.startswith('f',2,5))

True
False

string.strip([obj])

在 string 上执行 lstrip()和 rstrip()

用法:

name = '    fenggongzi     '
print (name.strip())
fenggongzi

string.swapcase()

翻转 string 中的大小写

用法:

name = 'FengGongZi'
print (name.swapcase())

fENGgONGzI

string.title()

返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())

用法:

name = 'FengGongZi'
print (name.title())Fenggongzi

string.translate(str, del="")

根据 str 给出的表(包含 256 个字符)转换 string 的字符,

要过滤掉的字符放到 del 参数中

用法:

string.upper()

转换 string 中的小写字母为大写

用法:

name = 'FengGongZi'
print (name.upper())FENGGONGZI

string.zfill(width)

返回长度为 width 的字符串,原字符串 string 右对齐,前面填充0

用法:

name = 'FengGongZi'
print (name.zfill(50))0000000000000000000000000000000000000000FengGongZi

string.isdecimal()

isdecimal()方法检查字符串是否只包含十进制字符。这种方法只存在于unicode对象。

用法:

name = 'FengGongZi1'
name1 = '123456'
print (name.isdecimal())
print (name1.isdecimal())

False
True