所以我知道 str.index(substring, begin, end=len(str)) 返回从 begin 开始的子字符串的第一个索引。有没有比简单地将开始索引更改为最后一次出现的索引 + 目标字符串的长度更好(更快、更干净)的方法来获取字符串的下一个索引?即(这是我正在运行的代码)
full_string = "the thing is the thingthe thing that was the thing that did something to the thing."
target_string = "the thing"
count = full_string.count(target_string)
print 'Count:', count
indexes = []
if (count > 0):
indexes.append(full_string.index(target_string))
i = 1
while (i < count):
start_index = indexes[len(indexes) - 1] + len(target_string)
current_index = full_string.index(target_string, start_index)
indexes.append(current_index)
i = i + 1
print 'Indexes:', indexes
输出:
Count: 5
Indexes: [0, 13, 22, 41, 73]
最佳答案
您可以使用 re.finditer
和列表理解:
>>> import re
>>> [m.start() for m in re.finditer(target_string, full_string)]
[0, 13, 22, 41, 73]
match objects有两个有用的方法.start()
和 .end()
, 这些返回与当前组匹配的子字符串的开始和结束索引。
另一种使用切片的方法:
>>> [i for i in xrange(len(full_string) - len(target_string) + 1)
if full_string[i:i+len(target_string)] == target_string]
[0, 13, 22, 41, 73]
关于python - 不仅查找字符串中子字符串的第一个索引 - python 2.7,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21442072/