Golang如何使用strings.LastIndex查找最后位置_Golang strings最后位置查找方法

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 main

import (
  "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
}

查找文件路径中的最后一个分隔符

一个实用的例子是提取文件名,可以通过查找最后一个路径分隔符实现:

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字符查找,要考虑其他方法。