strings.Index 和 strings.LastIndex 是 Go 中查找子串位置的基础函数,前者返回首次匹配索引,后者返回末次匹配索引,均区分大小写、不支持正则,未找到时返回 -1。

在 Go 语言中,查找子字符串在原字符串中的位置是常见操作,strings.Index 和 strings.LastIndex 是最基础、最高效的两个函数。它们都返回 int 类型的索引值,未找到时返回 -1,使用简单但细节需要注意。
strings.Index:从左往右找第一个匹配位置
strings.Index(s, substr) 在字符串 s 中从开头向后搜索子串 substr,返回首次出现的起始索引(从 0 开始)。如果没找到,返回 -1。
- 只匹配完整子串,不支持正则或通配符
- 区分大小写,
strings.Index("Hello", "h")返回-1 - 空字符串
""是特殊情况:对任意非空字符串s,strings.Index(s, "")恒为0 - 若
substr比s还长,直接返回-1
strings.LastIndex:从右往左找最后一个匹配位置
strings.LastIndex(s, substr) 从字符串末尾向前搜索,返回最后一次出现的起始索引。逻辑与 Index 对称,同样返回 -1 表示未找到。
- 适合提取文件后缀、URL 路径最后一段等场景,比如
strings.LastIndex("a/b/c.txt", ".")返回7 - 同样区分大小写,且对空字符串的处理一致:
strings.LastIndex("go", "")返回2(即字符串长度) - 注意:它找的是“最后一次完整匹配”,不是“最靠右的单字符匹配”
实际使用小技巧与避坑点
这两个函数虽简单,但容易在边界情况出错:
立即学习“go 语言免费学习笔记(深入)”;
- 判断是否存在时,别写
if idx != 0,而要写if idx != -1 - 提取子串时记得检查返回值,避免越界 panic:
if i := strings.Index(s, ":"); i != -1 {port := s[i+1:] } - 需要忽略大小写搜索?用
strings.ToLower预处理,或改用strings.IndexFold(Go 1.19+ 支持) - 想查多个分隔符中的任一个?
strings.IndexAny更合适;想查 Unicode 字符位置?得用strings.IndexRune
对比其他查找函数,按需选择
Go 的 strings 包还提供一组语义明确的变体:
-
IndexByte:查单个 字节(byte),比Index更快,适用于 ASCII 场景 -
IndexRune:按 Unicode 码点查找,正确处理中文、emoji 等多字节字符 -
IndexAny:在字符串中查找任意一个指定字符(如".,;:"中的任一符号) -
Contains:只需判断存在与否,语义更清晰,底层其实就调用了Index >= 0
基本上就这些。用对函数,少踩坑,字符串定位不复杂但容易忽略细节。






























