golang 八进制 utf-8 编码转中文
程序员文章站
2024-03-18 18:50:52
...
当调试程序,打印出变量的值时,有可能输出的是八进制 utf-8 编码(尤其是 protobuf 变量)
例如:\346\200\241\346\200\241\346\200
这样的字符串如果作为字面量,go可以自动转化,
但如果是从文件或string中读取,就不行了。
可以使用正则表达式
简单处理下
如下代码示例:
package main
import (
"fmt"
"regexp"
"strconv"
)
// 转换8进制utf-8字符串到中文
// eg: `\346\200\241` -> 怡
func convertOctonaryUtf8(in string) string {
s := []byte(in)
reg := regexp.MustCompile(`\\[0-7]{3}`)
out := reg.ReplaceAllFunc(s,
func(b []byte) []byte {
i, _ := strconv.ParseInt(string(b[1:]), 8, 0)
return []byte{byte(i)}
})
return string(out)
}
func main() {
s1 := "\346\200\241" // 字面量
s2 := `\346\200\241` // 原始字符串
fmt.Println("s1 =", s1)
fmt.Println("s2 =", s2)
// 转化 s2
s3 := convertOctonaryUtf8(s2)
fmt.Println("s3 =", s3)
}
运行结果:
推荐阅读
-
golang 八进制 utf-8 编码转中文
-
python3 requests 12306城市中文转英文编码
-
asp.net下UTF-7转GB2312编码的代码(中文)
-
asp.net下UTF-7转GB2312编码的代码(中文)
-
java ascii转中文(ascii转utf-8)清测好用 博客分类: java javaasciiutf-8
-
mysql无法插入中文的解决办法:修改数据库编码为utf-8
-
python实现unicode转中文及转换默认编码的方法
-
MYSQL数据库使用UTF-8中文编码乱码的解决办法
-
python实现unicode转中文及转换默认编码的方法
-
MYSQL数据库使用UTF-8中文编码乱码的解决办法