strings.LastIndex用于查找子串在原串中最后一次出现的索引,未找到返回-1。例如strings.LastIndex("hello world, hello golang", "hello")返回13,可用于提取文件名等场景,与strings.Index不同的是它返回最后而非首次匹配位置,适用于路径解析、文本处理等,但仅支持字符串不支持rune字符查找。

在Go语言中,strings.LastIndex 是一个常用的字符串处理函数,用于查找子字符串在原字符串中最后一次出现的位置。如果找到了,返回匹配位置的索引(从0开始);如果没有找到,返回 -1。
函数定义
func LastIndex(s, sep string) int参数说明:
- s:要搜索的原始字符串
- sep:要查找的子字符串
- 返回值:最后一次出现的索引位置,未找到返回 -1
基本用法示例
下面是一些常见的使用场景:
package mainimport (
"fmt"
"strings"
)
func main() {
str := "hello world, hello golang"
index := strings.LastIndex(str, "hello")
fmt.Println(index) // 输出: 13
notFound := strings.LastIndex(str, "xyz")
fmt.Println(notFound) // 输出: -1
singleChar := strings.LastIndex(str, "o")
fmt.Println(singleChar) // 输出: 24
}
查找文件路径中的最后一个分隔符
一个实用的例子是提取文件名,可以通过查找最后一个路径分隔符实现:
立即学习“go语言免费学习笔记(深入)”;
path := "/usr/local/bin/go.exe"sepIndex := strings.LastIndex(path, "/")
if sepIndex != -1 {
filename := path[sepIndex+1:]
fmt.Println(filename) // 输出: go.exe
}
与 strings.Index 的区别
- strings.Index:查找第一次出现的位置
- strings.LastIndex:查找最后一次出现的位置
例如:
s := "abcabc"fmt.Println(strings.Index(s, "a")) // 输出: 0
fmt.Println(strings.LastIndex(s, "a")) // 输出: 3
基本上就这些。strings.LastIndex 简单高效,适合处理需要定位末尾匹配的场景,比如解析路径、日志分析或文本处理等。不复杂但容易忽略的是,它只支持字符串,不能直接用于字符(rune),若需按Unicode字符查找,要考虑其他方法。










