9.30字符串

Part1

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

Part2

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)

2. 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

Part3

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))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值