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

Python Unicode编码

使用技巧 事实上,只要遵守以下规则,可以规避90%由于Unicode字符串处理引起的bug,剩下的10%通过python的库和模块能够解决。 程序中出现字符串时一定要加个前缀u。...你并没有考虑Unicode的兼容,直到项目快要结束……这时候再添加Unicode的支持几乎不太可能,不是吗?...修复对Unicode支持的bug可能会降低代码的可靠性,而且非常有可能引入新的bug。 总结:使应用程序完全支持Unicode,兼容其它的语言本身就是一个工程。它需要详细的考虑、计划。...所有涉及的软件、系统都需要检查,包括python的标准库和其他将要用到的第三方扩展模块。你甚至有可能需要组建一个经验丰富的团队来专门负责国际化(I18N)问题。...节选自《python核心编程(第二版)》P130、P131

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

    Python、Unicode和中文

    Python、Unicode和中文 python的中文问题一直是困扰新手的头疼问题,这篇文章将给你详细地讲解一下这方面的知识。...当然,几乎可以确定的是,在将来的版本中,python会彻底解决此问题,不用我们这么麻烦了。...把ChineseTest.py文件的编码重新改为ANSI,并加上编码声明: # coding=gbk s = "中文" print s 再试一下: E:/Project/Python/Test>python...我们这样写: # coding=gbk s = "中文" s1 = u"中文" s2 = unicode(s, "gbk") #省略参数将用python默认的ASCII来解码 s3 = s.decode...更进一步的例子,如果我们这里转换仍然用gbk: # coding=utf-8 s = "中文" print unicode(s, "gbk") 结果:中文 翻阅了一篇英文资料,它大致讲解了python中的

    1.1K20

    Python的bytes、str与unicode的区别

    编写高质量Python代码的59个有效方法--第三条:了解bytes、str与unicode的区别 Python3有两种表示字符序列的类型:bytes和str,这也是Python3最重要的特性之一...前者的实例包含原始的8位值;后者的实例包含Unicode字符。 Python2也有两种表示字符序列的类型:分别叫做str和unicode。...与python3不同的是,str的实例包含原始的8位值;而unicode的实例,则包含unicode字符。 把unicode字符表示为二进制数据(也就是原始8位值)有许多种办法。...最常见的编码方式就是utf-8。但是对于python3的str和python2的unicode实例都没有和特定的二进制编码形式相关联。...编写Python程序的时候,一定要把编码和解码操作放在界面最外围来做。程序的核心部分应该使用unicode字符类型,而且不要对字符编码做任何假设。

    48510

    Python | Python学习之unicode和utf8

    unicode unicode编码的出现解决了多国语言展示乱码的问题,但是unicode的解决方案在全英文文档展示的情况下,unicode编码会比ASCII编码多一倍的存储空间(unicode的编码是16bit...在python2.7中当要将字符串encode为utf8,我们需要确保之前的字符串的编码方式为unicode,所以当字符串编码不为unicode时,我们需要使用decode方法,而在使用decode方法时我们需要指明原有字符串的编码格式...所以在根据上面的情况,在python2中出现编码互转的情况,可以参考下图: ?...Python3.6 Python2.7和Python3.6最大的区别就是在执行Python2.7项目时,当项目中包含汉字时,需要在文件头声明编码格式,否则项目中的中文显示就是乱码。...而在Python3中完全没有这样的顾虑,那是因为默认python3中全部的字符串就是unicode可以直接使用encode方法。 ?

    1.1K60

    【python】str,unicode对象的encode和decode方法

    转自:链接 python的str,unicode对象的encode和decode方法 python中的str对象其实就是"8-bit string" ,字节字符串,本质上类似java中的byte[]...而python中的unicode对象应该才是等同于java中的String对象,或本质上是java的char[]。...对于 : s="你好" u=u"你好" 1. s.decode方法和u.encode方法是最常用的, 简单说来就是,python内部表示字符串用unicode(其实python内部的表示和真实的...8-bit strings(from Guido van Rossum) python之父的这段话大概意思是说encode方法本来是被unicode调的,但如果不小心被作为str对象的方法调,并且这个...用处2 非字符的编码集non-character-encoding-codecs,这些只在python中定义,离开python就没意义(这个来自python的官方文档) 并且也不是人类用的语言,呵呵。

    1.3K20

    python的str,unicode对象的encode和decode方法

    python的str,unicode对象的encode和decode方法  python中的str对象其实就是"8-bit string" ,字节字符串,本质上类似java中的byte[]。 ...而python中的unicode对象应该才是等同于java中的String对象,或本质上是java的char[]。 ...对于  Python代码   s="你好" u=u"你好" 1. s.decode方法和u.encode方法是最常用的,  简单说来就是,python内部表示字符串用unicode(其实...python内部的表示和真实的unicode是有点差别的,对我们几乎透明,可不考虑),和人交互的时候用str对象。 ...8-bit strings(from Guido van Rossum)  python之父的这段话大概意思是说encode方法本来是被unicode调的,但如果不小心被作为str对象的方法调,并且这个

    1.9K10

    python from __future__ import unicode_literals的作用

    ① Python的每个新版本都会增加一些新的功能,或者对原来的功能作一些改动。...有些改动是不兼容旧版本的,也就是在当前版本运行正常的代码,到下一个版本运行就可能不正常了 ② 从python2.7到Python 3.x就有不兼容的一些改动,比如2.x里的字符串用'xxx'表示str,...Unicode字符串用u'xxx'表示unicode,而在3.x中,所有字符串都被视为unicode,因此,写u'xxx'和'xxx'是完全一致的,而在2.x中以'xxx'表示的str就必须写成b'xxx...③ Python提供了__future__模块,把下一个新版本的特性导入到当前版本,于是我们就可以在当前版本中测试一些新版本的特性。...举例说明如下: ④ 为了适应Python 3.x的新的字符串的表示方法,在2.7版本的代码中,可以通过unicode_literals来使用Python 3.x的新的语法:在python3中默认的编码采用了

    55120

    python之分析decode、encode、unicode编码转换

    decode()方法使用注册编码的编解码器的字符串进行解码。它默认为默认的字符串编码。decode函数可以将一个普通字符串转换为unicode对象。...decode是将普通字符串按照参数中的编码格式进行解析,然后生成对应的unicode对象,比如在这里我们代码用的是utf-8,那么把一个字符串转换为unicode就是如下形式:s2=’哈’.decode...(‘utf-8′),s2就是一个存储了’哈’字的unicode对象,其实就和unicode(‘哈’, ‘utf-8′)以及u’哈’是相同的。...encode()方法正好就是相反的功能,是将一个unicode对象转换为参数中编码格式的普通字符,encode正好就是相反的功能,是将一个unicode对象转换为参数中编码格式的普通字符。...'unicode'>) print('--------------------------') # 将unicode编码转换为汉字,前边不带u的 str = '\u4eac\u4e1c\u653e\

    2.6K10

    Python Unicode编码混乱 :来自大洋彼岸的怨念

    Unicode已经解决了很多问题。知晓ISO-8859-*和CP437带来的混乱(当然对于非西方语言来说更糟糕)的人都可以证明这一点。当然,这些天他们正在做一项有的益工作——编码表情符号。...今日Python 3带来的痛苦更是一言难尽。 Python决定将Unicode完全集成到语言中。听起来很不错吧? 但众多问题也随之而来。...要想让Python程序正确地支持所有有效的Unix文件名,必须使用“bytes”而不是字符串,这可真够烦人的。所有Python程序正确的几率又能达到多少呢?我敢打赌,不会高的。...但是,强烈建议使用str类型,因为这样可以确保Unicode编码的文件名得到跨平台支持(在Windows上,Python 3.3开始,就已经不支持bytes编码的文件名了)。”...英文原文:http://changelog.complete.org/archives/9938-the-python-unicode-mess 译者:盈韬 来源:Python程序员 *声明

    66350

    Python脚本处理unicode字符时的解决方法

    我们在Python中,可以使用Unicode编码来表示字符。Unicode是一种字符集,它为世界上几乎所有的字符都分配了一个唯一的数字,这个数字被称为码点。...在Python中,在使用Unicode字符出现的问题又该如何解决?...1、问题背景在编写一个递归遍历目录树、列出所有.flac文件并从相应目录/子目录/文件名中提取艺术家、专辑和标题并将其写入文件的Python脚本时,发现代码在找到unicode字符时会出现错误。...2.x升级到Python 3.x版本,因为Python 3.x版本内置了对unicode字符的支持,无需进行额外的处理。..../')Python 3中的字符串默认使用Unicode编码,因此可以直接使用Unicode字符。例如,'你好'表示包含中文字符的字符串。上面就是今天的所有内容了,如果各位还有不懂的,一起留言讨论。

    14310
    领券