Python查找第n个子串的技巧分享

作者:WarmSword 时间:2023-02-20 22:02:55 

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

来源:https://blog.csdn.net/junbujianwpl/article/details/51834442

标签:Python,查找,子串
0
投稿

猜你喜欢

  • selenium获取当前页面的url、源码、title的方法

    2022-10-01 18:34:53
  • Python中捕获键盘的方式详解

    2021-06-14 15:23:41
  • 通过XSL转换XML文件步骤

    2008-01-27 16:03:00
  • 可用性测试过程中需要关注的一些细节

    2009-03-06 12:38:00
  • Django自定义用户认证示例详解

    2022-02-03 01:31:18
  • MySQL事务管理的作用详解

    2024-01-23 21:20:37
  • NumPy 与 Python 内置列表计算标准差区别详析

    2023-08-28 20:01:19
  • 利用Python脚本实现传递参数的三种方式分享

    2023-07-11 03:45:44
  • WEB开发中合理选择图片格式

    2011-09-22 20:32:06
  • Vue中的baseurl如何配置

    2024-05-09 15:10:46
  • 利用python打开摄像头及颜色检测方法

    2022-08-06 13:11:29
  • SQL Server 数据文件收缩和查看收缩进度的步骤

    2024-01-12 19:34:03
  • 全面解读Python Web开发框架Django

    2022-06-24 19:41:45
  • Javascript 中对中文长度对行判断

    2009-07-05 18:39:00
  • Django form表单与请求的生命周期步骤详解

    2023-06-20 06:29:15
  • SQLserver删除某数据库中所有表实现思路

    2024-01-25 21:06:40
  • Python用input输入列表的实例代码

    2021-09-22 09:33:53
  • 在SQL Server 2005数据库中更改数据架构

    2009-01-19 13:06:00
  • 用Python实现读写锁的示例代码

    2022-09-19 13:51:01
  • python标准库random模块处理随机数

    2023-11-23 16:22:49
  • asp之家 网络编程 m.aspxhome.com