python:lastIndexOf方法实现
1 前言
python没有类似java的获取字符串的某个字符最后出现的索引的方法,故而需要我们自行实现。我们可以根据python提供的string.index()方法来实现python的lastIndexOf方法。
2 使用
2.1 思路:
我们知道,python的string.index(substr, start)方法,可以使得字符串获取子字符串出现的位置时,从start开始的索引位置遍历子字符串substr(python的字符串索引位置,也是从0开始的),因此我们可以采用这个方法,一直循环向后获取子字符串的索引,直至出现ValueError时,返回上一次(即最近一次)的索引位置,也就是字符串的某个字符最后出现的索引位置了。
2.2 实际实现:
python自定义lastIndexOf方法如下:
str1 = "hello zzyouzz1"
def lastIndexOf(string: str, substr: str) -> int:
if string is None or substr is None:
raise ValueError("string and substr could not be None.")
elif not (isinstance(string, str) and isinstance(substr, str)):
raise TypeError("string and substr must be str type.")
elif not (len(string) > 0 and 0 < len(substr) <= len(string)):
raise TypeError("string and substr value must be non empty, "
"and string's length must more over than substr's length.")
last_index = -1
idx = 0
while True:
try:
index = string.index(substr, idx)
last_index = index
idx = index + len(substr)
except ValueError:
# 遍历直到substr在string中不存在,
# 那么直接返回索引last_index
return last_index
print(lastIndexOf(str1, 'zz'))
# 11
print(lastIndexOf(str1, 'z'))
# 12
print(lastIndexOf(str1, 'h'))
# 0
print(lastIndexOf(str1, '1'))
# 13
print(lastIndexOf(str1, 'l'))
# 3
print(lastIndexOf(str1, 'xiaoxu'))
# -1
print(lastIndexOf(str1, 'hello zzyouzz1'))
# 0
print(lastIndexOf("1.test.xlsx", '.'))
# 6
print(lastIndexOf(str1, ''))
# TypeError: string and substr value must be non empty,
# and string's length must more over than substr's length.
执行结果如下:
上述lastIndexOf方法,可以辅助我们获取文件的前后缀等等,使用场景如“test.txt”,获取最后出现“.”的索引位置,再获取文件后缀名等等。