1、字符串常用的方法
len()返回字符串的长度
##Python3 >>> print(len('ab12我')) 5 ##Python2 >>> print(len('ab12我')) 6
join()将字符串的每个元素按照指定的分隔符进行拼接
def join(self, iterable): return "" >>> str1='*' >>> str2='test' >>> str1.join(str2) 't*e*s*t'
split()切割字符串
##按指定字符串分割字符,分隔字符不保留,从左侧开始找 split(self, sep=None, maxsplit=-1) >>> str1='www.cnblogs.com' >>> print(str1.split('.')) ['www', 'cnblogs', 'com'] ##按指定字符串分割字符,分隔字符不保留,从右侧开始找 rsplit(self, sep=None, maxsplit=-1) >>> str1='www.cnblogs.com' >>> print(str1.rsplit('.')) ['www', 'cnblogs', 'com'] ##只能按照换行进行分割,参数为True表示保留换行符,False则不保留 splitlines(self, keepends=None) >>> str1='www.cn\nblogs.com' >>> print(str1.splitlines(True)) ['www.cn\n', 'blogs.com'] >>> print(str1.splitlines(False)) ['www.cn', 'blogs.com']
字符大小写转换
print(b.capitalize()) ##首字母大写 print(b.casefold()) ##除lower功能外,还有很多特殊的字符转换成小写,比如德文 print(b.lower()) ##字符小写,只能实现英文字符变小写 print(b3.islower()) ##判断字符是否全是小写 print(b.upper()) ##字符大写 print(b.isupper()) ##判断字符是否全部是大写 print(b.swapcase()) ##大写转小写,小写转大写 print(btitle.title()) ##将字符串转换成标题格式,所有单词首字母大写 print(btitle.istitle()) ##判断字符是否是标题格式
find()从字符的中寻找字符,成功返回下标,失败返回-1, 字符下标从0开始
def find(self, sub, start=None, end=None): return 0 >>> b='aS@cBß@1013,{name},{age}' >>> print(b.find('S',0,4)) 1 >>> print(b.find('ß',0,4)) -1
strip()取出字符串两端的特定字符
##去除左右空白,也可以去除指定字符,默认去除空格、\t、\n def strip(self, chars=None): return "" >>> str2='www.cnblogs.comwww' >>> print(str2.strip('w')) .cnblogs.com >>> str2='www.cnblogs.comwww' >>> print(str2.strip('w')) .cnblogs.com
查找和替换字符串中的字符
##替换字符,替换第一个,如果第三个参数为2代表替换前两个 replace(self, old, new, count=None): >>> str1='aS@cBß@1013' >>> print(str1.replace('@','222',2)) aS222cBß2221013 ##计算当前字符在字符串中出现的次数,从字符串第3个字符开始到第20个字符结束 count(self, sub, start=None, end=None) >>> str1='aS@cBß@10@13' >>> print(str1.count('@',3,20)) 2 >>> print(str1.count('*',3,20)) 0 ##从字符的【1,6)中寻找字符,成功返回下标,失败返回-1, 字符下标从0开始 find(self, sub, start=None, end=None) >>> str1='aS@cBß@10@13' >>> print(str1.find('S',1,5)) 1 >>> print(str1.find('*',1,5)) -1
填充字符串
##设置字符长度,字符居中,空白处*填充,默认空白,支持1个字符 center(self, width, fillchar=None) >>> str1='aS@cBß@10@13' >>> print(str1.center(20,'*')) ****aS@cBß@10@13**** ##左侧填充 ljust(self, width, fillchar=None) >>> str1='aS@cBß@10@13' >>> print(str1.ljust(20,'*')) aS@cBß@10@13******** ##右侧填充 rjust(self, width, fillchar=None) >>> str1='aS@cBß@10@13' >>> print(str1.rjust(20,'*')) ********aS@cBß@10@13
其他字符串操作
##join、split、find、strip、upper、lower、len b='aS@cBß@1013,{name},{age}' b1='xx{0},{1}xx' b2='1111xxxx\ty\tyyyy2222' b3='sfsgfisfg我' b4='12345②二' btitle='return true if all cased characters is s ' b5='_' print(b.format(name='Yong',age=19)) ##格式化字符串,指定名称 print(b1.format('Yong','xxx')) ##格式化字符串,必须从0开始 print(b.format_map({"name":'Yong',"age":19})) ##格式化字符串,传入的是map print(b.partition('a')) ##按指定字符将字符串串分割成三份,从左侧开始 print(b.rpartition('a')) ##按指定字符将字符串串分割成三份,从右侧开始 print(b.startswith('a')) ##判断字符是否以什么开始,返回True或False print(b.endswith('1')) ##判断字符是否以什么结尾,返回True或False print(b.index('c')) ##查找字符串,无法找到就抛错,可以忽略,使用find即可 print(b2.isalnum()) ##判断字符串中是否只包含字母或数字,返回True或False print(b3.isalpha()) ##判断字符是否只包含字母或汉字 print(b4.isdigit()) ##判断字符串是否只包含数字,可以判断字符②为数字 print(b4.isdecimal()) ##判断字符串是否只包含数字,只能判断纯数字,十进制 print(b4.isnumeric()) ##判断是否是数字,支持特殊②和中文的'二' print(b.isidentifier()) ##判断字符串是否是合法的标识符,字母数字下划线开头切只包含字母下划线和数字 print(b.isspace()) ##判断字符是否全是空格 print(b.isprintable()) ##答应出来的字符串和实际一致的时候为True否则为False, 比如包含\n \t, 打印的时候无法看到\n\t,就返回False print(b2.expandtabs(5)) ##按5个字符来断句,当遇到了\t就直接使用空格补全到5个字符,比如上述字符串以5分组,第二组为xxx\t 就会部2个空格,第三组为y\t,会补四个空格

浙公网安备 33010602011771号