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
基本上就这些。用对函数,少踩坑,字符串定位不复杂但容易忽略细节。
以上就是如何使用Golang查找字符串索引_Golang strings Index与LastIndex解析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1428673.html
微信扫一扫
支付宝扫一扫