find()方法——字符串首次出现的索引位置

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm=1001.2014.3001.5501

语法参考

find()方法实现查询一个字符串在其本身字符串对象中首次出现的索引位置,如起始位置从11到结束位置17之间子字符串出现的位置,如图1所示。如果没有检索到该字符串,则返回-1。

图1 find()方法示意图

find()方法的语法格式如下:

str.find(sub,start,end)

参数说明:

l str:表示原字符串。

l sub:表示要检索的子字符串。

l start:可选参数,表示检索范围的起始位置的索引,如果不指定,则从头开始检索。

l end :可选参数,表示检索范围的结束位置的索引,如果不指定,则一直检索到结尾。

例如,子字符串o在字符串www.mingrisoft.com起始位置从11到结束位置17之间首次出现的位置,如图2所示。

图2 字符串首次出现的位置

快用锦囊

锦囊1 检索邮箱地址中"@"首次出现中的位置

定义一个字符串,然后应用find()方法检索邮箱地址中首次出现"@"符号的位置索引,代码如下:

str1 = '790129881@qq.com'

print('@首次出现的位置为:',str1.find('@'))

运行程序,输出结果为:

@首次出现的位置为: 9

如果邮箱地址中没有"@",则返回值为-1,此时可以判断邮箱地址不正确并提示用户输入正确的邮箱地址。

说明:Python的字符串对象还提供了rfind()方法,其作用与find()方法类似,只是从字符串右边开始查找。

锦囊2 提取括号内数据

日常处理数据过程中,有时需要提取括号内的数据,例如图3所示括号内的手机号。

图3 提取括号内的手机号

下面使用find()方法查找括号所在位置,然后使用切片方法提取括号内的手机号,代码如下:

str1 = '张三(13566688888)'

l1=str1.find('(')

l2=str1.find(')')

print(str1[l1+1:l2])

运行程序,结果为:

13566688888

锦囊3 从邮箱地址提取ID并将首字母大写

一般情况下,邮箱地址都是由ID和服务器地址组成,那么通过邮箱地址就可以提取到ID或服务器地址。例如,提取ID并将首字母大写,效果如图4所示。

图4 邮箱地址

下面使用find()方法查找字符串中"@"的位置,然后使用切片方法提取ID并通过capitalize()方法设置首字母大写,代码如下:

file1 = open('./tmp/email.txt', 'r')

for value1 infile1.readlines():

l=value1.find('@')

print(value1[0:l].capitalize())

file1.close()

运行程序,结果为:

Gcytom

Jackeer

Mingrisoft

Mrkj_2019

相关推荐
bluebonnet27几秒前
【Python】一些PEP提案(五):注解的延迟求值
开发语言·python
InfinteJustice2 分钟前
mysql如何排查插件加载失败原因_mysql plugin目录与权限核对
jvm·数据库·python
qq_189807034 分钟前
Go语言怎么连接Elasticsearch_Go语言Elasticsearch教程【收藏】
jvm·数据库·python
橙露6 分钟前
Python 操作 MongoDB:非关系型数据查询与分析
开发语言·python·mongodb
赛博切图仔7 分钟前
前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
小魏小魏我们去那里呀8 分钟前
Java2Flowchart:一款把 Java 方法一键转换成 Mermaid 流程图的 IntelliJ 插件
java·ide·intellij-idea
小江的记录本10 分钟前
【RAG】RAG检索增强生成(核心架构、全流程、RAG优化方案、常见问题与解决方案)
java·前端·人工智能·后端·python·机器学习·架构
迷藏49412 分钟前
**TiDB 在高并发场景下的性能优化实战:从慢查询到极致吞吐的跃迁**在现代分布式系统中,数据库不仅是数据存储的
java·数据库·python·性能优化·tidb
程序员buddha13 分钟前
SCSS从0到1精通教程
前端·css·scss
m0_6784854513 分钟前
如何自动同步SQL异构表数据_利用触发器实现实时数据复制
jvm·数据库·python