Go 中文编码问题出现\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd\

LuYuChengProject · 2017-08-06 06:26:35 · 8277 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2017-08-06 06:26:35 的主题,其中的信息可能已经有所发展或是发生改变。

没有解析之前直接fmt.Println的时候是 ������ 这样的乱码 在用json.Marshal 解析一个数据的时候解析出来的中文变成了\ufffd\ufffd\ufffd\ufffd\ufffd\ufffd\ 这个样子,请问有什么办法吗?


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

8277 次点击  
加入收藏 微博
6 回复  |  直到 2017-08-07 04:18:17
marlonche
marlonche · #1 · 8年之前

字符串是不是UTF-8编码,go把字符串是当作UTF-8来解析的

mostsun1987
mostsun1987 · #2 · 8年之前

\ufffd 是uft8的边界值, go 不能解析的时候就会是这个, 一般都是因为编码不是utf8

littleFish
littleFish · #3 · 8年之前

Go都是按照utf8来解析字符串或文件的, 如果读出来是乱码, 请采用第三方编码转换包读取 https://github.com/djimenez/iconv-go

LuYuChengProject
LuYuChengProject · #4 · 8年之前
littleFishlittleFish #3 回复

Go都是按照utf8来解析字符串或文件的, 如果读出来是乱码, 请采用第三方编码转换包读取 `https://github.com/djimenez/iconv-go`

嗯,我用了官方的转码包。。最后发现问题还是没用,貌似是GBK的编码。但是Java里面转出来就是好的,有点麻烦。

littleFish
littleFish · #5 · 8年之前

#3楼 @littleFish 嗯,我用了官方的转码包。。最后发现问题还是没用,貌似是GBK的编码。但是Java里面转出来就是好的,有点麻烦。

发给我 我来搞搞

LuYuChengProject
LuYuChengProject · #6 · 8年之前
littleFishlittleFish #5 回复

#4楼 @LuYuChengProject 发给我 我来搞搞

那个是个种子文件里面的汉字乱码了,但是种子文件里面带有UTF-8的属性,所以解析的时候有个是乱码有个是UTF-8的汉字。果断放弃那个乱码了。O(∩_∩)O

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传