python-字符串学习

一、概念

str.lower() 全部转成小写,结果为新的字符串

str.upper()全部转成大写,结果为新的字符串

str.split(sep=None) 将字符串按照指定分隔符sep分隔,结果为列表类型

str.count(sub) 统计sub这个字符串在str中出现的次数

str.find(sub)查询是否存在,不在返回-1,在返回首次出现时的索引

如:

s = "Hello, world! Hello, world!"

index = s.find("world")

print(index) # 输出首次出现的位置(7)

str.index(sub),同上,但是不存在时报错

str.startswith(s)查询是否以子串s开头

str.endswith(s)查询是否以子串s结尾

str.replace(old,news,数字) 使用news替换字符串中所有的old字符串,结果是一个新的字符串;最后一个数字是替换次数,默认是替换全部

str.center(width,fillchar):字符串str在指定的宽度范围内居中,可以使用fillchar进行填充

str.join(iter):在iter中的每个元素拼接起来,以str为分隔符

str.strip(chars):字符串中去掉左右两侧chars中列出的字符串

str.lstrip(chars):字符串中去掉左侧chars中列出的字符串

str.rstrip(chars):字符串中去掉右侧chars中列出的字符串

格式化字符串的三种方法:

占位符:%s字符串格式型 %d十进制 %f浮点型

f-string

str.format()

二、代码练习

1、字符串创建和常见函数应用

str='helloWorD'
str1=str.lower()#转小写输出
print(str1)
str2=str.upper()#转大写输出
print(str2)
str3='hsd@123.com'
lst=str3.split('@')#以@符号分隔成两个
print(' 主机是'+lst[0]+' 域名是:'+lst[1])

print(str.count('l'))

print(str.find('o'))
print(str.index('o'))

print(str.startswith('h'))#判断是否以h开头
print(str.endswith('g'))#判断是否以g结尾

运行结果:

 2、字符串的格式化

name='李向类'
age=18
score=89.5
#第一种 占位符
print('姓名:%s,年龄:%d,成绩:%.1f'%(name,age,score))
#第二种 f-string
print(f'姓名:{name},年龄:{age},成绩:{score}')
#第三种 format
print('姓名:{0},年龄:{1},成绩:{2}'.format(name,age,score))#0,1,2值format里面的索引

 运行结果:

3、正则表达式re,sub,split应用

re:正则表达式库;re.sub() 替换函数。re.split()分隔函数

例如用sub实现敏感文字自动打码。

import re#正则表达式函数库
pattern='黑客|破解|反爬'
s='我想学习python破解一些视频VIP,可以实现反爬吗?'
s1=re.sub(pattern,'XX',s)#替换
print(s1)

s2='wwwn.dhuiehdue&duihiuh$bbcbehi'
pattern='[$|&]'
s3=re.split(pattern,s2)#分隔
print(s3)

 运行结果:

 4、正则表达式:match匹配,search搜索,findall查找函数应用

import re
#s='\d.\d+'
pattern='\d.\d+'#匹配模式
s='3.11i study python 3.11 every day'
match=re.match(pattern,s,flags=0)#匹配开始字符串
print(match)
s1='i study python 3.11 every day4.33'
match1=re.search(pattern,s1,flags=0)#搜索查找
print(match1)
lst=re.findall(pattern,s1)#查找全部
print(lst)

print('开始匹配的位置:',match.start())
print('结束匹配的位置:',match.end())
print('匹配的区间:',match.span())
print('待匹配的字符串:',match.string)
print('匹配的内容:',match.group())


import re
pattern=r'\s*@'
s='@杨淑娟 @胡说 @博览会额'

lst1=re.findall(pattern,s)
print(lst1)
lst=re.split(pattern,s)
print(lst)

 运行结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值