pythonlastIndexOf_0">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方法如下:
python">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 = -1idx = 0while True:try:index = string.index(substr, idx)last_index = indexidx = index + len(substr)except ValueError:# 遍历直到substr在string中不存在,# 那么直接返回索引last_indexreturn last_indexprint(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", '.'))
# 6print(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”,获取最后出现“.”的索引位置,再获取文件后缀名等等。