Python 3.2 字符串方法学习总结(3)

str.format(*args, **kwargs):
调用fortmat方法的字符串中不但有纯文本,也有使用{}界定符包括起来的替换字段。替换字段既可以是位置参数的数值索引,也可以是字典或属性的Key值。该方法返回的字符串里,所有替换字段都被相应参数的值所替代。如:
‘User ID: {0}’.format(‘root’) -->User ID: root
‘User ID: {UID} Last login: {last_login}’.format(UID = ‘root’, last_login = ‘5 Mar 2012’) -->User ID: root Last login: 5 Mar 2012

str.index(sub[, start[, end]]):
类似str.find(),但是如果没有找到子串,返回raised ValueError。

str.rindex(sub[, start[, end]]):
类似于str.rfind(),但是如果没有找到,返回raises ValueError。

str.replace(old, new[, count]):
返回一个新字符串,原串中的old被替换为new,country指定替换次数。如:
'AAABBBCCC'.replace('A', 'D') -->DDDBBBCCC
'AAABBBCCC'.replace('A', 'D', 2) -->DDABBBCCC

static str.maketrans(x[, [y, z]]):
这个方法我不是很明白,特别是它还有一个static修饰符。
大致上,��的用途是返回一个转换表,以供str.translate()方法使用,两个方法常配合使用。
如:
table = str.maketrans('cs', 'kz')
"please don't knock at my door!".translate(table) -->"pleaze don't knokk at my door!" //’c’被替换成了k,’s’被替换成了z。说明参数可以包含多个字符,但第一个参数包含的字符数和第二个参数包含的字符数必须相等。

table = str.maketrans('cs', 'kz', 'o')
"please don't knock at my door!".translate(table) -->"pleaze dn't knkk at my dr!" //如果有三个参数,则第三个参数的意思是删除原字符串中的相应字符。

str.translate(map):
和str.maketrans()函数配合使用,替换相应的字符。


拆分 & 组合类方法:
str.partition(sep):
该方法用于拆分字符串,返回一个包含三个元素的元组。如果未能在原字符串中找到Sep,则元组的三个元素为:原字符串,空串,空串;否则,从原字符串中遇到的第一个Sep字符开始拆分,元组的三个元素为:Sep之前的字符串,Sep字符,Sep之后的字符串;如:
'abcdee'.partition('f') --> ('abcdee', '', '')
'abcdee'.partition('e') --> ('abcd', 'e', 'e')

str.rpartition(sep):
与str.partition()相反,从原字符串的最右边开始拆分,但是同样返回包含三个元素的元组:倒数第一个Sep之前的字符串,Sep字符,Sep之后的字符串。
注意”倒数Sep之前的字符串”,这个之前的字符串,是从原字符串的最左边开始算,并不是最右边。如:
'abcdee'.rpartition('e') --> ('abcde', 'e', '') //拆分的三个元素分别是:倒数第一个e之前的元素,e本身,e之后的元素,此外为空格
'abcdee'.rpartition('f') --> ('', '', 'abcdee') //拆分的三个元素分别是:空格,空格,原字符串

str.split([sep[, maxsplit]]):
返回一个以Sep分隔的列表,maxsplit指定拆分次数(因此,列表中元素的个数为maxsplit + 1)。Sep默认为空格,maxsplit默认不限制拆分次数。
注意:1)如果未指定Sep或指定Sep为None(’’),str两端的空格将舍弃;如果指定Sep(不管能否在原字符串中找到Sep),str两端的空格将保留
2)如果未能在原字符串中找到Sep,则返回一个仅包含一个元素的列表,这个元素就是原字符串。
如:
' abcbdbee '.split() --> ['abcbdbee'] //未指定Sep,返回仅包含一个元素的列表,舍弃str两端的空格
' abcbdbee '.split('f') --> [' abcbdbee '] //指定f为Sep(虽然找不到f),返回仅包含一个元素的列表,保留两端的空格
' abcbdbee '.split('b') --> [' a', 'c', 'd', 'ee '] //指定b为Sep,不限定拆分次数,str两端的空格被保留
' abcbdbee '.split('b', 2) --> [' a', 'c', 'dbee '] //以b为分隔符,拆分两次
注:有点像str.partition(),但是str.partition()返回一个元组,而且分隔符Sep是元组中的一个元素;而str.split(0返回一个列表,分隔符Sep不在列表中

str.rsplit([sep[, maxsplit]]):
与str.split()类似,只是它从最右边开始拆分。只有在指定maxsplit的情况下才会看到效果。如:
'abcbdbee'.rsplit('b') --> ['a', 'c', 'd', 'ee'] //不指定maxsplit,返回的结果与str.split()相同
'abcbdbee'.rsplit('b', 2) --> ['abc', 'd', 'ee'] //可以看出与str.split(‘b’, 2)的差别

str.join(iterable):
使用连接符str来连接iterable对象中的元素,返回一个被str连接起来的,由iterable对象的元素组成的字符串。如果传入一个非iterable对象,如整数、布尔值等,将返回Type Error。 如:
‘A B’. join(['1', '2', '中国']) -->1A B2A B中国
‘A B’.join(‘12中国’) -->1A B2A B中国
‘A B’.join(123) -->Type Error
注:iterable object或iterator type最主要的特征是支持两个函数:__iter__()和__next__(),虽然不是很准确,但可以简单的认为支持使用for语句逐个取值的数据类型都是迭代器对象。
sequence type(六种:strings、byte objects、byte arrays、lists、tuples、range objects)和dictionary都属于iterable对象。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/ce6c44a788420bff83c3f6471d1af731.html