字符串的Python中最常用的数据类型,用引号('
或"
)来创建字符串。
字符串是不可变的。
字符串支持序列的通用操作,此外,还有很多字符串方法。
字符串方法
-
find()
方法:用于检测字符串中是否包含子字符串str。如果包含子字符串,就返回开始的索引值;否则返回-1.
str.find(str, beg=0, end=len(string))
beg指定开始位置,默认值为0;end指定结束位置,默认值为字符串的长度。
>>> string = 'as you like'
>>> string.find('ou')
4
>>> string.find('at')
-1
-
join()
方法: 用于将序列中的元素以指定字符连接成一个新字符,返回一个新字符串。
str.join(seq)
用join()
操作调用和被调用的对象必须都是字符串。
>>> string = [1,2,3,4,5]
>>> string = 'hello'
>>> '--'.join(string)
'h--e--l--l--o'
-
lower()
方法:用于将字符串中所有大写字母转换成小写。
str.lower()
>>> str = 'try IT NOW'
>>> str.lower()
'try it now'
-
upper()
方法:用于将字符串中小写字母转换成大写字母。
str.upper()
>>> str = 'try IT NOW'
>>> str.upper()
'TRY IT NOW'
-
swapcase()
方法:用于对字符串的大小写字母进行转换,将字符串中的大写字母转换成小写字母,小写字母转成大写字母。
str.swapcase()
>>> str = 'try IT NOW'
>>> str.swapcase()
'TRY it now'
-
replace()
方法:把字符串中的old(旧字符串)替换为new(新字符串),替换次数不超过max(可选参数)。
str.replace(old, new [,max])
当不指定第3个参数时,所有匹配的字符都被替换;当指定第3个参数时,替换从左到右,替换次数不超过指定次数。
>>> str = 'do it now, try it now.'
>>> str.replace('do','just do')
'just do it now, try it now.'
>>> str
'do it now, try it now.'
>>> str.replace('o','2o2',2)
'd2o2 it n2o2w, try it now.'
-
split()
方法:通过指定分隔符对字符串进行切片。是join()
方法的逆方法.
str.split(st="", num = string.count(str))
>>> str = 'do it now, try it now.'
>>> str.split()
['do', 'it', 'now,', 'try', 'it', 'now.']
>>> str
'do it now, try it now.'
>>> str.split('o')
['d', ' it n', 'w, try it n', 'w.']
>>> str.split('o',1)
['d', ' it now, try it now.']
-
translate()
方法:根参数table给出的表(包含256个字符)转换字符串的字符,将要过滤掉的字符放到del参数中。
str.translate(table [, deletechars])
-
strip()
方法:用于移除字符串头尾指定的字符(默认为空格)。返回的结果是移除字符串头尾指定的字符生成的新字符串。
str.strip([chars])
>>> str = ' do it now '
>>> str.strip()
'do it now'
>>> s = '-----doing the job -------'
>>> s.strip('-')
'doing the job '
capitalize()
将字符串的第一个字符转换为大写center(width, fillchar)
返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。count(str, beg= 0,end=len(string))
返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数bytes.decode(encoding="utf-8", errors="strict")
Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。encode(encoding='UTF-8',errors='strict')
以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'endswith(suffix, beg=0, end=len(string))
检查字符串是否以suffix 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.expandtabs(tabsize=8)
把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。
index(str, beg=0, end=len(string))
跟find()方法一样,只不过如果str不在字符串中会报一个异常.isalnum()
如果字符串至少有一个字符并且所有字符都是字母或数字则返 回True
,否则返回False
isalpha()
如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False
-
isdigit()
如果字符串只包含数字则返回 True 否则返回 False..
islower()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 Falseisnumeric()
如果字符串中只包含数字字符,则返回 True,否则返回 Falseisspace()
如果字符串中只包含空白,则返回 True,否则返回 False.istitle()
如果字符串是标题化的(见 title())则返回 True,否则返回 False
-
isupper()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
len(string)
返回字符串长度ljust(width[, fillchar])
返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。lstrip()
截掉字符串左边的空格或指定字符。maketrans()
创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。max(str)
返回字符串 str 中最大的字母。min(str)
返回字符串 str 中最小的字母。rfind(str, beg=0,end=len(string))
类似于 find()函数,不过是从右边开始查找.rindex( str, beg=0, end=len(string))
类似于 index(),不过是从右边开始.rjust(width,[, fillchar])
返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串rstrip()
删除字符串字符串末尾的空格.splitlines([keepends])
按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。startswith(str, beg=0,end=len(string))
检查字符串是否是以 str 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。title()
返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见
istitle()
)
zfill (width)
返回长度为 width 的字符串,原字符串右对齐,前面填充0isdecimal()
检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。
2018.05.29 更新:
-
zfill()
方法
返回指定长度的字符串,原字符串右对齐,前面填充0。
语法:str.zfill(width)
, width是指定字符串的长度。原字符串右对齐,前面填充0
>>> s= 'aaa'
>>> s.zfill(10)
'0000000aaa'