String bulit-in function
tip:
和tuple一样,字符串也是不可变的类型,字符串的内建函数有非常多,我们一一举例来看看他们的作用
下面是用dir(str) 输出的内容:
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
1.capitalize 把字符串的第一个字符大写
2.casefold python3中新添加的,具体作用是给其它除英语以外的语言改成小写。(跳过
3.center 居中
s = "this is string example....wow!!!" print ("str.center(40, 'a') : ", str.center(40, 'a')) # 此处40代表的是输出结果的字符串长度,‘a’指的是填充物,若没有这个参数,默认填充空格 >>>str.center(40, 'a') : aaaathis is string example....wow!!!aaaa
4.count 不解释
5.encode 以encode指定的编码格式编码string
s = u'djc' # s 是unicode s.encode(encoding='UTF-8',errors='ignore') # 此处把s转变成了UTF-8的形式,后面的errors 可以是ignore 或者 replace,也可以不填,那样的话如果出错会报ValueError print(s)
6.endswith 检查字符串尾部 对应的有一个startswith 检查字符串是否以xxx开头,和endswith类似
s = 'djc is a asshole' v = s.endswith('e',3,9) # 检测字符串在3到9的范围内是否是以e结尾,很显然是False print(v) >>>False
7.expandtabs 把字符串中的tab符号转换成空格,默认空格数tabsize = 8
8.find
s = 'djc is a asshole' v = s.find('m') # 检测 m 是否包含在 s 中,若不在返回-1,若在返回该字符所在位置位置,如果是一串字符,则返回第一个字符所在位置 print(v) >>>-1
9.format
name = 'deng {0} is {1}' print(name.format('asshole','sad')) # 字符串的拼接,这个函数的语法是把asshole和sad赋值给{0}和{1},这也是字符串格式化的一种 name = 'deng {name} is {id}' print(name.format(name = 'asshole',id = 'sad'))
10.format_map 现在我也不知道,日后再来补充
11.index 和find功能一样,区别在于find找不到会返回-1,而index会报错
12.isalnum
s = 'djc.1' v = s.isalnum() # 如果字符串中至少有一个字符并且所有字符都是数字或字母则返回Ture,否则返回False print(v) >>>False
13.isalpha 和上面的类似,只不过是只有当全部是字符是就会返回Ture
14.isdecimal string中只包含10进制数则返回Ture,否则返回False
15.isdigit string中只包含数字则返回Ture,否则返回False
16.isidentifier string中是否是关键字是则返回Ture,否则返回False
17.islower
s = 'sdasd123' v = s.islower() # string中包含一种区分大小写的字符,并且这些字符都是小写,则返回Ture,否则返回False,因为数字不区分大小写,所以不影响结果
print(v)
>>> Ture
18.isnumeric 和isdight功能,全是数字则返回Ture,否则返回Flse
19.isprintable 跳过
20.isspace string中如果只包含空格,则返回Ture,否则返回False
21.istitle string中如果是标题化的则返回Ture,否则是False。标题化见title()
22.isupper 和islower相反,全是大写则返回Ture,否则是False
23.join
#对序列进行操作(分别使用' '与':'作为分隔符) >>> seq1 = ['hello','good','boy','doiido'] >>> print ' '.join(seq1) hello good boy doiido >>> print ':'.join(seq1) hello:good:boy:doiido
s = 'hello good boy doiido'
>>> print ':'.join(seq1.split(sep = ' ') # split() 参数sep = ‘ ’,以空格分割字符串s
hello:good:boy:doiido #对字符串进行操作 >>> seq2 = "hello good boy doiido" >>> print (':'.join(seq2)) h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o >>> print #对元组进行操作 >>> seq3 = ('hello','good','boy','doiido') >>> print (':'.join(seq3)) hello:good:boy:doiido #对字典进行操作 >>> seq4 = {'hello':1,'good':2,'boy':3,'doiido':4} >>> print (':'.join(seq4) boy:good:doiido:hello #合并目录 >>> import os >>> os.path.join('/hello/','good/boy/','doiido') '/hello/good/boy/doiido'
24.ljust
str = "djc is a asshole" print (str.ljust(50, '0')) # 返回一个原字符串左对齐,默认用空格填充
>>>djc is a asshole0000000000000000000000000000000000
25.rjust 跟上面一样,只不过是右对齐
26.lower 将string中的大写字符全部转换成小写
27.upper 和lower相反
28.swapcase 翻转string中的大小写
29.lstrip 截掉string左边的空格
s = " djc is a asshole" v = s.lstrip() print(v)
>>>djc is a asshole
30.maketrans
语法: str.maketrans(intab, outtab]); # 详细见http://blog.csdn.net/u014351782/article/details/46740297 Python maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式, 第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 注:两个字符串的长度必须相同,为一一对应的关系。 Python3.4已经没有string.maketrans()了,取而代之的是内建函数: bytearray.maketrans()、bytes.maketrans()、str.maketrans() """ intab = "abcd" outtab = "1234" str_trantab = str.maketrans(intab,outtab) test_str = "csdn blog: http://blog.csdn.net/wirelessqa" print (test_str.translate(str_trantab))
>>>3s4n 2log: http://2log.3s4n.net/wirelessq1
31.partition 返回一个三元tuple rpartition 从右边开始查找,和partition类似
s = 'djc is a asshole' v = s.partition('ass') # 返回一个参数左边,参数,参数右边组成的三元元祖 print(v)
>>>('djc is a ', 'ass', 'hole')
32.replace 替代
s = 'djc is a asshole'
v = s.replace('s','d',1) # 把s字符串中的s替换成d,最后那个参数表示最多替换多少次,此处为一次因此只换了一次
print(v)
>>>djc id a asshole
33.rfind 和find类似,不过是从右边开始查找
34.rindex 和index类似,不过是从右边开始索引
35.split
s = 'djc is a asshole' v = s.split(' ',2) # 以空格为分隔符,分割两次,默认为有多少分多少 print(v)
>>>['djc', 'is', 'a asshole']
36.splitlines 分割行,字符串中有\n就\n这分割,相当于split('\n')
37.strip 删除字符串左右两边的空格
38.title 返回标题化的string,就是说所有的单词都是以大写开始,其余字母都是小写
39.translate 与maketrans一起使用,详情见30
40.zfill 返回长度为width的字符串,原字符串string右对齐,前面填充0
a = 'djc is a asshole' v = a.zfill(40) print(v)
>>>000000000000000000000000djc is a asshole
好多QAQ