Python中的字符串查找操作方法总结

作者:mink的小屋 时间:2021-06-13 12:21:46 

基本的字符串位置查找方法
Python 查找字符串使用 变量.find("要查找的内容"[,开始位置,结束位置]),开始位置和结束位置,表示要查找的范围,为空则表示查找所有。查找到后会返回位置,位置从0开始算,如果每找到则返回-1。


str = 'a,hello'
print str.find('hello') # 在字符串str里查找字符串hello
>> 2     # 输出结果

朴素匹配算法

朴素匹配算法是对目标字符串和模板字符串的一一匹配。如果匹配得上,下标向右移一位, 否则清空并重新开始匹配。


target = 'abb aba'
pattern = 'aba'

def match(target, pattern):
 i = j = 0
 n, m = len(target), len(pattern)
 while i < n and j < m:
   # 如果字符相等则目标和模板的下标都向右移
   if target[i] == pattern[j]:
     i, j = i+1, j+1
   else:
     # 如果字符不相等则目标下标切换到不相等的下标
     # 模板下标移动到初始下标
     i = i - j + 1
     j = 0
 if j == m:
   return i - j
 return -1

把上面的加上print后打印一遍


#修改的地方
else:
 i = i -j + 1
 j = 0
 print(target[i], pattern[j], i, j)

# 打印结果
b a 1 0
b a 2 0
a 3 0
a a 4 0

循环会一直到相等的匹配值, 这个方法效率低下,主要是在不匹配时会重新把模板字符循环一次。最多可能会出现 m * (n-m +1)次。m是模板字符的长度,n-m + 1是排除不等字符的次数。

KMP 算法

kmp是通过已知匹配的字符进行移位的算法,比如上面的abb 中跟abc比较的话 ab是已知的。


def match(target, pattern):
 i = j = 0
 n, m = len(target), len(pattern)
 while i < n and j < m:
   # 如果字符相等则目标和模板的下标都向右移
   if if j == -1 and target[i] == pattern[j]:
     i, j = i+1, j+1
   else:
     # 这里通过next 函数来判断位移个数
     i = i - j + pattern_next(pattern[:j])
     j = 0
 if j == m:
   return i - j
 return -1

def pattern_next(s):  
 prefix = [s[:i+1] for i in range(len(s)-1)]
 suffix = [s[i+1:] for i in range(len(s)-1)]
 l = list(set(prefix) & set(suffix))
 return len(l)
标签:Python,字符串,查找
0
投稿

猜你喜欢

  • mysql使用left join连接出现重复问题的记录

    2024-01-25 06:10:30
  • python+appium自动化测试之如何控制App的启动和退出

    2023-06-24 12:45:01
  • 使用Python的toolz库开始函数式编程的方法

    2022-10-18 10:29:55
  • Vue + Webpack + Vue-loader学习教程之相关配置篇

    2024-04-29 13:10:40
  • Python PyQt4实现QQ抽屉效果

    2023-10-08 08:06:42
  • 如何在Django项目中引入静态文件

    2021-10-09 11:24:52
  • Python对字符串实现去重操作的方法示例

    2021-12-12 11:46:37
  • Thinking XML: 创建 XML 的好建议

    2008-05-29 11:25:00
  • js动态创建上传表单通过iframe模拟Ajax实现无刷新

    2024-05-22 10:40:32
  • Vue项目中使用setTimeout存在的潜在问题及解决

    2024-05-28 16:00:14
  • php mysql procedure实现获取多个结果集的方法【基于thinkPHP】

    2023-11-19 08:27:32
  • 学习 YUI3 中的沙箱机制

    2010-04-12 12:52:00
  • 搜索结果页(SERP):个性化如何影响用户行为?

    2009-07-22 21:00:00
  • JavaScript 函数惰性载入的实现及其优点介绍

    2024-04-16 09:25:37
  • [机器视觉]使用python自动识别验证码详解

    2021-09-12 03:24:36
  • 浅析Flask如何使用日志功能

    2023-06-17 17:18:21
  • python获取从命令行输入数字的方法

    2021-08-23 15:19:02
  • Python图像处理实现两幅图像合成一幅图像的方法【测试可用】

    2022-11-13 08:36:56
  • wdcp添加tomcat,同时支持php和java教程

    2023-10-09 10:39:38
  • Python实现将数据写入netCDF4中的方法示例

    2023-12-30 15:51:18
  • asp之家 网络编程 m.aspxhome.com