最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 14:29:13
文档

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

Python中的字符串查找操作方法总结:基本的字符串位置查找方法 Python 查找字符串使用 变量.find(要查找的内容[,开始位置,结束位置]),开始位置和结束位置,表示要查找的范围,为空则表示查找所有。查找到后会返回位置,位置从0开始算,如果每找到则返回-1。 str = 'a,hello
推荐度:
导读Python中的字符串查找操作方法总结:基本的字符串位置查找方法 Python 查找字符串使用 变量.find(要查找的内容[,开始位置,结束位置]),开始位置和结束位置,表示要查找的范围,为空则表示查找所有。查找到后会返回位置,位置从0开始算,如果每找到则返回-1。 str = 'a,hello

基本的字符串位置查找方法
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)

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

Python中的字符串查找操作方法总结:基本的字符串位置查找方法 Python 查找字符串使用 变量.find(要查找的内容[,开始位置,结束位置]),开始位置和结束位置,表示要查找的范围,为空则表示查找所有。查找到后会返回位置,位置从0开始算,如果每找到则返回-1。 str = 'a,hello
推荐度:
标签: 操作 查找 里的
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top