登录
首页 >  Golang >  Go教程

Golang字符串长度索引与子串获取技巧

时间:2026-01-18 22:18:49 447浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《Golang字符串长度索引及子串获取方法》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

Go中字符串是UTF-8字节序列,len(s)返回字节数而非字符数;应使用for range遍历rune,或转[]rune切片操作字符。

如何在Golang中使用字符串长度和索引_获取字符和子串

在 Go 中,字符串是 UTF-8 编码的字节序列,不是 Unicode 码点数组。因此,直接用索引访问“字符”可能出错——尤其遇到中文、emoji 等多字节字符时,下标取到的是单个字节,而非完整字符。

字符串长度 ≠ 字符个数

Go 的 len(s) 返回字节数,不是 rune(Unicode 码点)个数。例如:

s := "你好"
len(s) → 6(每个中文占 3 字节)
utf8.RuneCountInString(s) → 2(真正有 2 个字符)

用 for range 安全遍历字符(rune)

这是获取每个“逻辑字符”的推荐方式,自动按 UTF-8 解码:

  • 每次迭代得到 index(字节偏移)和 rune(Unicode 码点)
  • 适合逐个处理字符、查找位置、统计字符数

s := "Go编程?"
for i, r := range s {
  fmt.Printf("位置 %d: %c (U+%04X)\n", i, r, r)
}

按字节索引取子串:仅限 ASCII 或明确字节边界场景

若确定字符串全是 ASCII(如英文、数字、符号),可安全用切片:

  • s[2:5] → 取第 2 到第 4 个字节(左闭右开)
  • s[0] → 第一个字节(对 ASCII 就是第一个字符)
  • ⚠️ 对中文或 emoji 直接用 s[1] 可能截断 UTF-8 编码,导致乱码或 panic

按字符位置获取子串:先转为 rune 切片

需要“第 n 个字符”或“从第 i 个字符起取 m 个字符”,必须先转成 []rune

  • runes := []rune(s) —— 将字符串解码为 Unicode 码点切片
  • runes[1] → 第二个字符(rune 类型)
  • string(runes[1:3]) → 从第 2 个字符起取 2 个字符组成的字符串

s := "Hello世界"
rs := []rune(s)
fmt.Println(string(rs[0:5])) // "Hello"
fmt.Println(string(rs[5:7])) // "世界"

好了,本文到此结束,带大家了解了《Golang字符串长度索引与子串获取技巧》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>