字符串进阶
一、字符串相关方法
-
字符串拼接
1.字符串.join(序列) - 将序列中的元素用指定的字符串拼接在一起,形成一个新的
字符串。(序列中的元素必须是字符串)
# 举例 list1 = ['后羿', '王昭君', '鲁班七号', '孙悟空'] result = ''.join(list1) print(result) # '后羿王昭君鲁班七号孙悟空' result = '+'.join(list1) print(result) # '后羿+王昭君+鲁班七号+孙悟空' result = 'and'.join(list1) print(result) # '后羿and王昭君and鲁班七号and孙悟空' result = '*'.join('abc') print(result) # a*b*c
2.如果需要join的序列中的元素不是字符串,就想办法把它的元素变成字符串再join
nums = [223,45,67, 89, 45] result = ''.join([str(i) for i in nums]) print(result) # '22345678945'
-
切割
1.字符串1.split(字符串2) - 将字符串1中所有的字符串2作为切割点对字符串进
行切割,返回包含切割后每一小段对应的字符串的列表。切割点会消失。
str1 = 'abcmn123mnkplmn##' result = str1.split('mn') print(result) # ['abc', '123', 'kpl', '##']
2.字符串1.split(字符串2,N) - 将字符串1中前N个字符串2作为切割点为字符串1进行切割
str1 = 'abcmn123mnkplmn##' result = str1.split('mn', 2) print(result) # ['abc', '123', 'kpl##']
-
替换
1.字符串1.replace(字符串2, 字符串3) - 将字符串1中所有的字符串2替换成
字符串3
str1 = 'mnabcmnmn123mnkpl##mn' result = str1.replace('mn', 'ABC') print(result) # ABCabcABCABC123ABCkpl##ABC
2.字符串1.replace(字符串2, 字符串3, N) - 将字符串1中前N个字符串2替换
成字符串3
str1 = 'mnabcmnmn123mnkpl##mn' result = str1.replace('mn', 'AB', 3) print(result) # ABabcABAB123mnkpl##mn
-
删除空白字符
1.字符串.strip() - 删除字符串左右两端的空白字符
2.字符串.rstrip() - 删除字符串右端的空白字符
3.字符串.lstrip() - 删除字符串左端的空白字符
str1 = '\n\t 小 明\n\t' print(str1) print('==============华丽的分割线===============') result = str1.strip() print(result) # 小 明
-
find、index
1.字符串1.find(字符串2) - 获取字符串1中字符串2第一次出现的位置(以0
开始的下标值返回),如果字符串2不存在返回-1。
2.字符串1.find(字符串2,开始下标,结束下标) - 获取字符串1中指定范围内
字符串2第一次出现的位置(以0开始的下标值返回-1)。
3.字符串1.index(字符串2) - 获取字符串1中字符串2第一次出现的位置(以
0开始的下标值返回),如果字符串2不存在报错。
4.字符串1.index(字符串2,开始下标,结束下标) - 获取字符串1中字符串2第
一次出现的位置(以0开始的下标值返回),如果字符串2不存在报错。
str1 = 'how are you? I am fine, thank you! and you?' print(str1.find('you')) # 8 print(str1.index('you')) # 8 print(str1.find('abc')) # -1,表示没有找到 # print(str1.index('abc')) # 报错!substring not found print(str1.find('you', 10)) # 30 print(str1.find('you', 10, 26)) # -1
-
其他方法
1.casefold()
print('abcMN123'.casefold()) # abcmn123
2.center、rjust、ljust、zfill -------
‘abc’ -> ‘xxabcxx’,‘xxxxabc’, ‘abcxxxx’, ‘0000abc’
str1 = 'abc' print(str1.center(7, '+')) # ++abc++ print(str1.ljust(7, '*')) # abc**** print(str1.rjust(7, '&')) # &&&&abc print(str1.zfill(7)) # 0000abc
3.count - 统计字符串中xx出现的的次数
str1 = 'mnabcmnmn123mnkpl##mn' print(str1.count('a')) # 1 print(str1.count('mn')) # 5
4.endswith、startswith
str1 = 'mnabcmnmn123mnkpl##mn' print(str1.endswith('abc')) # False print(str1.endswith('#mn')) # True print(str1.startswith('ab')) # False print(str1.startswith('mn')) # True
5.format、f ---- 格式化
name = '小明' age = 18 # 'xxx今年xx岁!' result = str.format('{}今年{}岁', name, age) print(result) # 小明今年18岁 result = f'{name}今年{age}岁' print(result) # 小明今年18岁
6.isdecimal、isdigit、isnumeric 、islower(全是小写字母)
print('2323'.isdecimal()) # True print('323a3'.isdecimal()) # False print('2323--'.isdecimal()) # False print('==============华丽的分割线===============') print('232311'.isdigit()) # True print('2323+11'.isdigit()) # False print('2323--'.isdigit()) # False print('==============华丽的分割线===============') print('2323'.isnumeric()) # True print('232a3'.isnumeric()) # False print('2323--'.isnumeric()) # False print('hgaj'.islower()) # True print('x'.islower()) # True
案例:
# 输出字符串里所有数字 str1 = '722实际上飞机22-2233=+集合289' for i in str1: if i.isdigit(): print(i)
7.maketrans、translate - 根据映射表对应的关系替换字符串中的相关
字符
str1 = '1727283112shanshuo2nsnk2' # 创建一个映射表 table = str.maketrans('1234567890', '一二三四五六七八九零') # 根据映射表对应的关系替换字符串中的相关字符 result = str1.translate(table) print(result) # 一七二七二八三一一二shanshuo二nsnk二 # 案例 # 星期一 str1 ='星期1, 星期2, 星期3,星期4, 星期5, 星期6, 星期7' table = str.maketrans('1234567','一二三四五六天') result = str1.translate(table) print(result) # 星期一, 星期二, 星期三,星期四, 星期五, 星期六, 星期天
二、字符串格式化
解决字符串内容变化
-
字符串拼接
name = '小明' age = 18 message = name + '今年' + str(age) + '岁!' print(message) # 小明今年18岁!
-
格式字符串
1.语法:包含一个或者多个格式占位符的字符串 % (数据1,数据2,数据3,…)
2.说明:()中的数据必须和前面字符串中的占位符一一对应,如果只需要
一个数据,那么()可以省略
3.常用的字符串占位符:
%s - 可以给任何类型的数据占位(字符串占位符)
%d - 只能给数字数据占位(整数占位符)
%f - 只能给数字数据占位(浮点数占位符,默认保留6位小数)
%.Nf - 只能给数字数据占位(保留N位小数)
name = '小明' age = 18 message = '%s今年%d岁!' % (name, age) print(message) # 小明今年18岁! result = '%s%s%s' % ('abc', 12, [10, 20]) print(result) # abc12[10, 20] result = '%d-%d' % (12, 2) print(result) # 12-2 result = '%f-%f' % (2.3, 34) print(result) # 2.300000-34.000000 result = '%.2f-%.1f' % (2.3, 34) print(result) # 2.30-34.0
-
f-string
f-string的参数:{提供数据的表达式: 参数}
name = '小明' age = 18 money = 15000 str1 = '姓名:{name}, 年龄:{age}' print(str1) # 姓名:{name}, 年龄:{age} str2 = f'姓名:{name}, 年龄:{age}' print(str2) # 姓名:小明, 年龄:18 str3 = f'a:{age}, b:{100}, c{100*2}, d:{100>200}, c: {name*2}, d:{name[-1]}' print(str3)
1.控制小数位数: {提供数据的表达式: .Nf}
money = 672828279 result = f'余额:{money:.2f}元' print(result) # 余额:672828279.00元 num = 102.3447 result = f'个数:{num:.0f}' print(result) # 个数:102 money = 16500 result = f'年薪:{money*13:.2f}元' print(result) # 年薪:214500.00元
2.大金额逗号分割: {提供数据的表达式:,}
money = 165009000 result = f'金额:{money:,}元' print(result) # 金额:165,009,000元 # {提供数据的表达式:,.Nf} - 既控制小数位数,又使用逗号 result = f'金额:{money:,.2f}元' print(result) # 金额:165,009,000.00元
3.小数显示成百分比:{提供数据的表达式:,.N%}
scale = 0.34 result = f'及格率:{scale:.1%}' print(result) # 及格率:34.0%
4.控制填充长度(实现center、rjust、ljust、zfill的功能):
{提供数据的表达式:字符^长度}、{提供数据的表达式:字符>长度}、
{提供数据的表达式:字符<长度}、 如果没有其他字符,会用空格填充
num = 6 result = f'{num:0>3}' print(result) # 006 result = f'{num:x>7}' print(result) # xxxxxx6 result = f'{num:x<7}' print(result) # 6xxxxxx result = f'{num:x^7}' print(result) # xxx6xxx result = f'编号:{num:>7}' print(result) # 编号: 6 nums = [155, 1, 92, 9, 23, 899, 18, 5821, 47, 8993] for i in nums: print(f'{i:>4}')