package main

import (
    "fmt"
)

func main() {
    str := "我爱你"
    fmt.Println(str)  // 可以直接显示
    fmt.Println(str[0:2]) // 显示乱码??
}

想问一下,这种直接截取字符串的方法,为什么会导致乱码?


对golang的这种设计,我也是表示很不喜欢
如果你是c#或者java的习惯,可以采用我这个库
https://github.com/golangframework/xstring

import(
  "github.com/golangframework/xstring"
)

s1:="你好,我是李萌萌同学"
s2:=xstring.Substring(s1,5,3)://李萌萌

转成rune,按照字符去操作


编码问题,一个汉字是三个byte,你只截了两个byte,所以就显示不全了。


如果包含中文,需要将字符串转换为rune数组后再进行截取,再将结果转换成string


自己做了下测试,有三种显示方法,谢谢各位。

package main

import "fmt"

func main() {

    str1 := "我爱你"
    str2 := []rune(str1)

    // 第一种方法
    fmt.Println(string(str2[:]))

    // 第二种方法
    for i := 0; i < len(str2); i++ {
        fmt.Printf("%c", str2[i])
    }

    // 第三种方法
    for _, m := range str1 {
        fmt.Printf("%c", m)
    }
}

不懂go,但八成是编码问题

一个中文字是用多个字节表示,UTF8用3个字节,Unicode用2个字节,GBK用2个字节。

但go可能并不知道,还将它当成单字节字符来看。因此你会截出一个半字。这半个字就表现为乱码。

解决方案: 可一律转成unicode编码,或使用库中可操纵多字节字符的函数