字符串操作
1.in 和 not in
字符串1 in 字符串2 - 判断字符串1是否是字符串2的子串(判断字符串2中是否包含字符串1)
print(‘a’ in ‘abc’) # True
print(‘ab’ in ‘abc’) # True
print(‘ac’ in ‘abc’) # False
2.相关函数
len、str
1)求长度
str1 = ‘曾经有一段真挚的爱情…’
print(len(str1))
str2 = ‘\tabc\n123’
print(len(str2)) # 8
str3 = r’\tabc\n123’
print(len(str3)) # 10
str4 = ‘abc 123’
print(len(str4)) # 8
str5 = ’ abc123’
print(len(str5)) # 10
2)str(数据) - 将数据准换成字符串
a.哪些能转:所有的数据都可以转换成字符串
b.怎么转:在数据打印值外面加引号
num = 100
print(str(num)) # ‘100’
print(str(True)) # ‘True’
print(str([1, 2, 3])) # ‘[1, 2, 3]’
c.字符串转数字
str6 = ‘782’
print(int(str6))
去掉引号后本身是整数的字符串才能转换成整型
str7 = ‘12.5’
print(int(str7))
str8 = ‘12.5’
print(float(str8)) # 12.5
print(float(str6)) # 782.0
str9 = ‘3e4’
print(float(str9)) # 30000.0
s3 = {10, [1, 2]}
print(s3)
格式化字符串
name = input(‘请输入姓名:’)
name = ‘小明’
age = int(input(‘请输入年龄:’))
age = 23
money = float(input(‘请输入月收入:’))
money = 78273.982
message: xxx今年xx岁,月薪xxxx元
message = name+‘今年’+str(age)+‘岁,月薪’+str(money)+‘元’
print(‘加法运算:’, message)
当一个字符串中有一个或者多个部分是变化的的时候,我们可以用字符串加法运算、格式字符串和f字符串来实现这个功能
1.格式字符串
“”"
格式字符串:在字符串中用格式占位符代替字符串变化的部分,然后在后面用数据来给格式占位符赋值
语法:
带有格式占位符的字符串 % (数据1,数据2,数据3,…)
说明:
1)% - 固定写法
2)() - 固定写法,在数据只有一个可以省略
3)数据 - 数据的个数必须和前面字符串中占位的个数保持一致;类型也要和占位符一一对应
4)格式占位符 - 格式占位符有哪些,对应的数据的类型是什么都是固定的
%s - 字符串(可以是其他数据)
%d - 整数
%f - 浮点数; %.Nf - 浮点数保留N位小数
%c - 字符/字符编码值
“”"
message = ‘%s今年%d岁,月薪%.2f元, 等级:%c’ % (name, age, money, 65)
print(‘格式字符串:’, message)
- f-string
“”"
1)format方法
包含{}的字符串.format(数据1,数据2,…) - 字符串中{}就相当于格式字符串中的占位符
“”"
1)基本用法
a.{}
message = ‘{}今年{}岁,月薪{}元’.format(name, age, money)
print(‘format1:’, message)
b.{下标} - 下标指的是获取format中第几个数据,从0开始
‘xxx的年龄:xx, 今年xx岁’
message = ‘{1}的年龄:{0}, 今年{0}岁’.format(age, name)
print(‘format2:’, message)
c.{key}
message = ‘{y}的年龄:{x}, 今年{x}岁’.format(x=age, y=name)
print(‘format3:’, message)
2)格式约束: {:约束条件}、{下标:约束条件}、{key:约束条件}
“”"
约束条件:
.Nf - 保留N位小数(四舍五入)
符号>Nd - 约束数据宽度为N,不够的在前面用指定符号填充
符号<Nd - 约束数据宽度为N,不够的在后面用指定符号填充
, - 将数字三位一组用逗号隔开(一般用于大数据的表示)
% - 将小数转换成百分比数据,保留6位小数
.N% - 将小数转换成百分比数据,保留N位小数
“”"
print(‘约束1:{:.2f}’.format(3.1415926)) # 约束1:3.14
print(‘约束1:{0:.3f}’.format(3.1415926)) # 约束1:3.142
print(‘约束2:{:0>5}’.format(100)) # 约束2:xx100
print(‘约束2:{:0<5}’.format(23)) # 约束2:23000
print(‘约束2:{: >5}’.format(‘abc’)) # 约束2: 34
print(‘约束3:{:,}’.format(1000000)) # 约束3:1,000,000
print(‘约束4:{:%}’.format(0.2356)) # 约束4:23.560000%
print(‘约束4:{:.1%}’.format(0.2356)) # 约束4:23.6%
3)f-string - format方法的简写
“”"
语法:
f’字符串内容’
“”"
message = f’{name}今年{age}岁,月薪:{money}元!’
print(message) # 小明今年23岁,月薪:78273.982元!
message = f’{name*2}今年{age+10}, 月薪:{money/1000}K’
print(message)
添加约束
print(f’pi:{3.1415926:.2f}’) # pi:3.14
print(f’年龄:{age: >5}’) # 年龄: 23
字符串相关方法
1.字符串1.count(字符串2) - 统计字符串1中字符串2出现的次数
message = ‘how are you? i am fine, Thank you, and you?’
print(‘you 的个数:’, message.count(‘you’)) # 3
print(‘空格的个数:’, message.count(’ ')) # 9
2.字符串1.find(字符串2) - 获取字符串2第一次在字符串1中出现的位置(返回的是下标值), 如果找不到就返回-1
message = ‘how are you? i am fine, Thank you, and you?’
print(message.find(‘you’)) # 8
print(message.find(‘a’)) # 4
print(message.find(‘你好’)) # -1(找不到)
字符串1.find(字符串2,开始下标,结束下标) - 获取字符串2在字符串1指定范围内第一次出现的位置
print(message.find(‘you’, -7)) # 39 (在’nd you?'找 ‘you’)
print(message.find(‘you’, 0, 10)) # -1 (在’how are yo’找 ‘you’)
3.字符串.join(字符串序列) - 将序列中所有的元素用指定字符串拼接产生一个新的字符串
list1 = [‘name’, ‘age’, ‘abc’, ‘你好’]
new_str = ‘’.join(list1)
print(new_str) # ‘nameageabc你好’
print(’+’.join(list1)) # ‘name+age+abc+你好’
message = ‘hello’
new_str = ’ '.join(message)
print(new_str) # ‘h e l l o’
print(‘😁😢’.join(message)) # h😁😢e😁😢l😁😢l😁😢o
看一眼! [str(x) for x in nums] - 列表推导式
nums = [100, 20, 30, 40]
print(’’.join([str(x) for x in nums])) # 100203040
4.字符串1.replace(字符串2, 字符串3) - 将字符串1中所有的字符串2都替换成字符串3,产生一个新的字符串
字符串1.replace(字符串2, 字符串3, N) - 将字符串1中前N个字符串2替换成字符串3
message = ‘how are you? i am fine, Thank you, and you?’
new_str = message.replace(‘you’, ‘YOU’)
print(new_str) # how are YOU? i am fine, Thank YOU, and YOU?
new_str = message.replace(‘you’, ‘me’, 2)
print(new_str) # how are me? i am fine, Thank me, and you?
5.字符串1.split(字符串2) - 将字符串1中的字符串2作为切割点对字符串1进行切割
message = ‘how are you? i am fine, Thank you, and you?’
print(message.split(’ ')) # [‘how’, ‘are’, ‘you?’, ‘i’, ‘am’, ‘fine,’, ‘Thank’, ‘you,’, ‘and’, ‘you?’]
str1 = ‘abc123abc123abc’
print(str1.split(‘123’)) # [‘abc’, ‘abc’, ‘abc’]
print(str1.split(‘1’)) # [‘abc’, '23abc, ‘23abc’]
print(str1.split(‘b’)) # [‘a’, ‘c123a’, ‘c123a’, ‘c’]
print(str1.split(‘c’)) # [‘ab’, ‘123ab’, ‘123ab’, ‘’]
str2 = ‘abc123abcc123’
print(str2.split(‘c’)) # [‘ab’, ‘123ab’, ‘’, ‘123’]
字符串1.split(字符串2, N) - 将字符串1中的前N个字符串2作为切割点对字符串1进行切割
message = ‘how are you? i am fine, Thank you, and you?’
print(message.split(’ ', 2)) # [‘how’, ‘are’, ‘you? i am fine, Thank you, and you?’]
6.字符串.zfill(N) - 将字符串转换成一个指定长度的新字符串,原字符串在右边,左边用0填充
num = 34
print(str(num).zfill(4))