"/home/hernan/PycharmProjects/test1/tensor.py".find('e') #Returns 4
"/home/hernan/PycharmProjects/test1/tensor.py".find('e',2) #Also 4
"/home/hernan/PycharmProjects/test1/tensor.py".find('e',3) #Also 4
我想要类似的东西:
"/home/hernan/PycharmProjects/test1/tensor.py".find('e',2) #Returns 7
"/home/hernan/PycharmProjects/test1/tensor.py".find('e',3) #Returns 14
是'e'的第二和第三次。
答案 0 :(得分:1)
为什么不仅仅使用for循环?
def find_nth(text, sub, nth):
start = -1
for i in range(nth):
start = text.find(sub, start + 1)
if start == -1:
break
return start
find_nth("/home/hernan/PycharmProjects/test1/tensor.py", 'e', 2) # returns 7
find_nth("/home/hernan/PycharmProjects/test1/tensor.py", 'e', 3) # returns 24
答案 1 :(得分:0)
str.find
函数中的第二个参数表示起始索引。不是要开始查找的事件的索引。 'find a char'.find('a', 3)
等效于'find a char'[3:].find('a') + 3
(某种程度;不处理要在其中搜索的完整字符串中不存在的搜索字符串)。您必须为此编写自己的函数。
def search(full, toFind, occ):
ret = 0
while occ:
ret = full.find( toFind, ret ) + 1
occ -= 0
if ret == -1:
return -1
return ret