Problem
Python中str类自带的find、index方法可以返回第一个匹配的子串的位置,但是如果实际使用中需要查找第2个甚至第n个子串的位置该怎么办呢。也许有的码友可能会用到第二第三个参数,指定查找的起始、终止位置。但是在很多情况下,接收到的一个字符串可能是未知的,强制限定起始位置可能导致代码在某些情况下不能适用。
Solution
采用嵌套的方法调用find或者index。
str_exp = "aaabbbbccc" pos_n = str_exp.index("a", str_exp.index("a")+1) print(pos_n)
原理很简单,第一次查找返回的位置加1作为第二次查找的起始参数。加1是因为start参数位置是被包含的,采用的闭区间的语义。也不用担心会越界,python底层已经做了处理。
也可以写一个单独的函数来进行查找操作。
def find_n_sub_str(src, sub, pos, start): index = src.find(sub, start) if index != -1 and pos > 0: return find_n_sub_str(src, sub, pos - 1, index + 1) return index
pos表示第n个子串,从0开始。start为起始位置。此处使用find而不用index是因为index在查找失败时会报出异常,而find不报异常返回-1。从健壮性考虑使用find。
看来递归使用起来还是可以解决很多编程实践过程中遇到的工程问题。:)
Attention
1、左闭右开特性
str.index(self, sub, start=None, end=None) str_tmp[start:end]
默认的是左闭右开,即包含start的位置,却不包含end的位置。在使用过程中需要注意一下。同样左闭右开的还有切片操作str_tmp[start:end]。
示例如下:
str_exp = "aaabbbbccc" print(str_exp) print(str_exp[str_exp.index("a"):str_exp.rindex("c")])
aaabbbbccc aaabbbbcc
2、find与index差别
find是不会报出异常的,即查找子串失败的情况下返回-1,而index在查找子串失败时会报异常。
示例如下:
str_tmp = "aaaabbbbccccdddd" print(find_n_sub_str(str_tmp, "a", 5, 0)) print(str_tmp.find("a", 7)) print(str_tmp.index("a", 7))
-1 -1 Traceback (most recent call last): File "/usr/local/pycharm-community-5.0.4/helpers/pydev/pydevd.py", line 2411, in <module> globals = debugger.run(setup['file'], None, None, is_module) File "/usr/local/pycharm-community-5.0.4/helpers/pydev/pydevd.py", line 1802, in run launch(file, globals, locals) # execute the script File "/usr/local/pycharm-community-5.0.4/helpers/pydev/_pydev_imps/_pydev_execfile.py", line 18, in execfile exec(compile(contents+"\n", file, 'exec'), glob, loc) File "/usr/local/workspace/pycharmPro/StockAI/StockAI/DbDealer.py", line 140, in <module> print(str_tmp.index("a", 7)) ValueError: substring not found
以上这篇Python查找第n个子串的技巧分享就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]