首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

utf-8,gbk,gb2312,unicode 编码

我们常常听到如下编码UTF-8GBK、GB2312 和 Unicode。这些编码方式之间有何不同呢?下面我们来详细了解一下。...同时,UTF-8 编码也能够支持多种语言字符的表示,使得不同语言之间的交流变得方便。 2.GBK GBK 是中国国家标准的编码方式,主要应用于中文编码。...它是一种双字节编码,能够表示的字符范围比较有限,主要涵盖了简体中文和部分繁体中文。 GBK 编码的优点在于它能够支持中文字符的表示,而且相对于 UTF-8 编码来说,它的编码效率更高一些。...但是,GBK 编码的范围比较有限,对于一些生僻字或者少数民族字符就无法表示。 3.GB2312 GB2312 是中国国家标准的另一种编码方式,它是 GBK 的前身。...同时,GB2312 编码的兼容性不如 GBKUTF-8,因此在现代的应用中使用的较少。 通过上面的介绍,可以了解到utf-8, gbk, gb2312的区别。

22030
您找到你想要的搜索结果了吗?
是的
没有找到

Python 有关 Unicode UTF-8 GBK 编码问题详解

2.UTF-8 编码 互联网的普及,强烈要求出现一种统一的编码方式。UTF-8 就是在互联网上使用最广的一种 unicode 的实现方式。...重复一遍,这里的关系是,UTF-8 是 Unicode 的实现方式之一。 UTF-8 最大的一个特点,就是它是一种变长的编码方式。...UTF-8编码规则很简单,只有二条: 对于单字节的符号,字节的第一位设为 0,后面 7 位为这个符号的 unicode 码。因此对于英语字母,UTF-8 编码和 ASCII 码是相同的。...with open(file_path, encoding='utf-8') as f: f.read() 当使用 gbk 编码保存的文件使用 utf8 打开时会报错,使用 gbk 打开即可 with...open(r'gbk.txt','r',encoding='utf-8') as f: print(f.read()) 错误信息: (result, consumed) = self

1.6K10

unicode、utf-8、ansi、gbk、gb2312编码详解

unicode、utf-8、ansi、gbk、gb2312编码详解 前言 作为一个开发人员或是测试人员,免不了要与各种各样的编码打交道,而且这些各种编码总是让人头大,现在我们就来揭开他们的庐山真面目 移动还是联通...于是扩展呗,把之前gb2312中没有利用的位好好利用起来,就成了gbk,这又增加了20000多个汉字,但是咱们少数名族也要用电脑啊,于是有了后来的 GB18030 GB2312和GBK都是用两个字节来编码的...终 现在我们就可以来看一下联通干不过移动的原因了,因为我们在记事本中不指定存储编码时默认时ansi,在中国的电脑上也就是gbk编码,而联通的gbk编码是: c1 1100 0001 aa 1010 1010...没错,它就是与utf-8编码冲突了,在我们第二次打开记事本的时候,记事本误以为它是utf-8编码。...于是就按照utf-8的格式解析了,我们去掉模板后,再补上前导0:00000000 01101010 转为16进制:006A 对应unicode是小写字符j ?

3.6K62

UNICODE,GBK,UTF-8

UNICODE,GBK,UTF-8 UNICODE,GBK,UTF-8     简单来说,unicode,gbk和大五码就是编码的值,而utf-8,uft-16之类就是这个值的表现形式.而前面那三种编码是一兼容的...,同一个汉字,那三个码值是完全不一样的.如"汉"的uncode值与gbk就是不一样的,假设uncode为a040,gbk为b030,而uft-8码,就是把那个值表现的形式.utf-8码完全只针对uncode...整理这篇文章的动机是两个问题: 问题一: 使用Windows记事本的“另存为”,可以在GBK、Unicode、Unicode big endian和UTF-8这几种编码方式间相互转换。...对于Unicode(UCS2)、GBKUTF-8这些编码方式,我原来就了解。但这个程序让我有些糊涂,想不起来UTF-16和UCS2有什么关系。...4、UTF编码 UTF-8就是以8位为单元对UCS进行编码

2.6K20

Unicode,GBKUTF-8

但如果有人问你,“Unicode,GBKUTF-8有什么区别?”, 你能自信地给他一句简短清晰的回答吗? 如果不能的话, 那还是看一下这篇文章吧....('utf8').decode('gbk') 浣犲ソ 如上面的代码所示, “你好"两个汉字字符的unicode分别为4f60和597d, utf-8编码后占6个字节, 而gbk编码后占4个字节....注: 本文的python代码示例是在Linux Terminal下运行的, 因此默认为utf-8编码, 如果你是在Windows cmd里运行, 则通常默认GBK编码, 因此乱码会在不同地方出现:)...后记 说了这么多, 现在让我们回到一开始的问题, 如果有人问你"Unicode,GBKUTF-8有什么区别?”..., 我想你应该知道该怎么回答了吧: Unicode是 一种字符集, 而GBKUTF-8都是编码, 因此Unicode和后两者不是一类事物, 是无法进行对比的.

1.5K20

字符编码那点事:快速理解ASCII、Unicode、GBKUTF-8

于是厂商微软利用GB 2312-80未使用的编码空间,收录GB 13000.1-93全部字符制定了GBK编码。...虽然GBK收录GB 13000.1-93的全部字符,但编码方式并不相同。GBK自身并非国家标准,只是曾由国家技术监督局标准化司、电子工业部科技与质量监督司公布为"技术规范指导性文件"。...简单来说:Unicode、GBK和Big5码等就是编码的值(也就是术语“字符集”),而UTF-8、UTF-16、UTF32之类就是这个值的表现形式(即术语“编码格式”)。...以UTF-8为例,UTF-8码完全只针对Unicode来组织的,如果GBK要转UTF-8必须先转Unicode码,再转UTF-8就OK了。...《字符编码那点事:快速理解ASCII、Unicode、GBKUTF-8》 >> 更多同类文章 …… (本文同步发布于:http://www.52im.net/thread

2.1K20

Java编码ASCII、GB2312、GBK、Unicode、UTF-8、UTF-16 编码方式详解

3 GBK GB2312有局限性,只能表示6000个字符,GBK是对GB2312的升级,GBK与GB2312非常相似,唯一的不同: 结构 使用GBK编码,当读取到一个数值上小于127的字节时当作一个ASCII...仅仅是一点微小的变化,让GBK在2312的基础上多增加了20000余个字符,GBK也是我们最常用的中文编码表。...相比较UTF-8GBK需要的空间小,如果我们工作的受众对象是汉语对象,使用GBK没有问题,但需注意java语言使用unicode编码,有可能会存在转换问题导致乱码,使用需谨慎。...UTF-8是unicode编码的一种实现。 结构 UTF-8灵活性很强,用1~4个字节表示一个字符。 当字符在ASCII中可以被表示时,UTF-8编码方式就用一个字节来表示它。...UTF-16容错情况比UTF-8好,因为UTF-16稳定使用两个字节编码,如果数据错误不会连代其他数据被读错,而UTF-8是变长编码,可能导致后面的字符全部错误。

2K10

字符编码技术专题(一):快速理解ASCII、Unicode、GBKUTF-8

2、专题目录本文是“字符编码技术专题”系列文章的第 1 篇,总目录如下:《字符编码技术专题(一):快速理解ASCII、Unicode、GBKUTF-8》(* 本文)《字符编码技术专题(二):史诗级计算机字符编码知识入门...4)UTF-8编码是六个字节EF BB BF E4 B8 A5,前三个字节EF BB BF表示这是UTF-8编码,后三个E4B8A5就是严的具体编码,它的存储顺序与编码顺序是一致的。...于是厂商微软利用GB 2312-80未使用的编码空间,收录GB 13000.1-93全部字符制定了GBK编码。...简单来说:Unicode、GBK和Big5码等就是编码的值(也就是术语“字符集”),而UTF-8、UTF-16、UTF32之类就是这个值的表现形式(即术语“编码格式”)。...以UTF-8为例,UTF-8码完全只针对Unicode来组织的,如果GBK要转UTF-8必须先转Unicode码,再转UTF-8就OK了。

74240

UNICODE,GBK,UTF-8区别

UNICODE,GBK,UTF-8区别     简单来说,unicode,gbk和大五码就是编码的值,而utf-8,uft-16之类就是这个值的表现形式.而前面那三种编码是一兼容的,同一个汉字,那三个码值是完全不一样的....如"汉"的uncode值与gbk就是不一样的,假设uncode为a040,gbk为b030,而uft-8码,就是把那个值表现的形式.utf-8码完全只针对uncode来组织的,如果GBK要转UTF-8...整理这篇文章的动机是两个问题: 问题一: 使用Windows记事本的“另存为”,可以在GBK、Unicode、Unicode big endian和UTF-8这几种编码方式间相互转换。...对于Unicode(UCS2)、GBKUTF-8这些编码方式,我原来就了解。但这个程序让我有些糊涂,想不起来UTF-16和UCS2有什么关系。...参考推荐: UNICODE,GBK,UTF-8区别 字符编码详解及由来(UNICODE,UTF-8,GBK) gbk, gb2312,big5,unicode,utf-8,utf-16之间的关系 中文字符集简介

2.9K21

UTF-8编码

介绍 UTF-8 编码UTF-8 是一种针对 Unicode 的可变长度字符编码。针对 Unicode:UTF-8 是 Unicode 的实现方式之一。...---技术是为了解决问题而生的,UTF-8 编码是为了解决什么问题而设计的呢?UTF-8 是为了兼容 ASCII 编码而设计的。...这样,可以快速读取和写入 UTF-8 编码的字符。UTF-8 编码的缺点UTF-8 编码不利于使用正则表达式进行读音检索正则表达式可以进行很多高级的英文模糊检索。...同样 GBK 编码的中文也可以这样利用正则表达式,比如在只知道一个字的读音而不知道怎么写的情况下,也可用正则表达式检索,因为 GBK 编码是按读音排序的。...在只知道一个字的部首而不知道如何发音的情况下,UTF-8 可用正则表达式检索而 GBK 不行。

1.6K00

简述 ascii、unicode、utf-8gbk 的关系

每一个符号都给予一个独一无二的编码,那么乱码问题就会消失。这就是Unicode,就像它的名字都表示的,这是一种所有符号的编码。 互联网的普及,强烈要求出现一种统一的编码方式。...UTF-8就是在互联网上使用最广的一种Unicode的实现方式。UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度。...UTF-8中,英文占一个字节,中文占3个字节。...由于GBK同时也涵盖了Unicode所有CJK汉字,所以也可以和Unicode做一一对应。windows默认编码GBK,中文占2个字节。  ...比如,“李杰”,在  utf-8中,一个英文占一个字节,一个中文占3个字节,此处“李杰”占6个字节。GBK中一个中文占2个字节,此处“李杰”占4个字节。

1.8K10

【错误记录】IntelliJ IDEA 中编译运行报错 ( 当前设置 GBK 编码 | 错误: 编码UTF-8的不可映射字�? )

\src\main\java\ArrowCanvas.java:17: 错误: 编码UTF-8的不可映射字�?...二、 解决方案 ---- 在 Windows 环境下的 IntelliJ IDEA 中 , 使用 GBK 编码 , 运行程序是不会出错的 ; 命令行默认的编码UTF-8 编码 , 如果在 命令行 中运行...GBK 编码 的 程序 , 如果项目中有中文注释 , 或者打印中文内容 , 就会出现 错误: 编码UTF-8的不可映射字�?...=GBK 指定执行程序的编码GBK 编码 ; 如果是在 IntelliJ IDEA 环境中 , 选择 " Edit Configurations… " 选项 , 在弹出的 " Run/Debug...; 经过上面的设置后 , 再次运行程序 , 就不会出现 错误: 编码UTF-8的不可映射字�?

2.9K20
领券