Python2中文处理纪要

python2不是以unicode作为基本代码字符类型,碰到乱码的几率是远远高于python3,但即便如此,相信很多人,也不想随意的迁移到python3,这里就总结几个我平常碰到的问题及解法。

  1. 文件中无法使用中文注释 处理方法: 在代码中增加# -*- coding=UTF-8 -*-,一般加在文件头部第一行,如果第一行是脚本标志,则放在第二行(实际仍然是python正本的第一行)。 随后将文件另存为UTF-8格式。 此方法可以解决注释中有中文,及字符串立即数中包含中文的问题。
  2. unicode中文变量打印出来是乱码 处理方法: 文件开始引入扩展库的部分加入以下3行代码。 import sys reload(sys) sys.setdefaultencoding('utf-8')
  3. utf-8 及 gbk互相转换 直接看代码: #utf-8字符串转换成GBK(GB2312及其它编码也是这样用) print str.decode('UTF-8').encode('GBK') #gbk转换成utf-8 print str.decode('GBK').encode('UTF-8')
  4. 参数中的utf-8是用大写还是小写? 通常大小写都可以,这不是python决定的,是系统的语言代码设定决定的。
  5. 打开utf-8的文本文件 经过1、2的设置,正常直接打开就可以,文件是什么编码,读出来就是什么编码,个别仍有不行的可以使用扩展库codecs: import codecs ... with codecs.open(poetry_file, "r","utf-8") as f:
  6. print打印出来的结构中的汉字是乱码 print仅打印一个utf-8的变量是不会有问题的,比如 a="汉字" print a #会正常显示 但是如果用了接续显示,比如: print a, #将会显示乱码 如果是其它结构,诸如dict / list / class等,都会出现乱码。 a = ["中文","测试"] print a #将会显示乱码 这种情况使用基本库没有什么好办法,只能循环逐个打印内容,比如: ... for item in items: print item 或者整合输出,比如:print ', '.join(a) 还可以使用第三方的包,比如: import uniout ... listnine = ['梨', '橘子', '苹果', '香蕉'] print 'listnine list: %s' % listnine
  7. 变量本身显示正常,循环遍历出来的单个字符乱码 大多情况是因为字符串不是unicode编码。声明字符串的时候使用a = u'汉字'这样方式赋值的变量都是Unicode字符串,不会有问题。 如果是从外部传入的变量,源头情况又不知道,可以尝试转换成Unicode字符串: str=unicode(str,"utf-8");

嗯,差不多就这些,想到再补充。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏java系列博客

深入理解Java内存模型(二)——重排序

2194
来自专栏LIN_ZONE

PHP 常用设计模式 (转载)

单例模式顾名思义,就是只有一个实例。作为对象的创建模式, 单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例。

1642
来自专栏编程

大神用Python编写虚拟机解释器

群内不定时分享干货,包括最新的python企业案例学习资料和零基础入门教程,欢迎初学和进阶中的小伙伴入群学习交流 ? 环境介绍 环境采用带桌面的Ubuntu L...

2188
来自专栏云霄雨霁

在现有线程安全类中添加功能

1774
来自专栏java思维导图

Java中高级面试题部分答案解析(2)

这里是一些题型解析,还是这些话:不一定全部正确,有一些是没有固定答案的,如果发现有错的或者更适合的答案欢迎留言矫正。

951
来自专栏IT可乐

JVM 运行时的内存分配

  首先我们必须要知道的是 Java 是跨平台的。而它之所以跨平台就是因为 JVM 不是跨平台的。JVM 建立了 Java 程序和操作系统之间的桥梁,JVM 是...

2128
来自专栏IT技术精选文摘

易犯的Java内存泄漏代码

Java隐式地通过GC(守护线程)回收内存。 GC定期检查是否存在无法访问的对象,或者确切地说,没有指向该对象的引用。如果是这样,GC回收新可用的内存。 现在...

2227
来自专栏欧阳大哥的轮子

深入解构iOS系统下的全局对象和初始化函数

事件源于接入了一个第三方库导致应用出现了大量的crash记录,很奇怪的是这么多的crash居然没有收到用户的反馈信息! 在这个过程中每个崩溃栈的信息都明确的指向...

2292
来自专栏沈唁志

在PHP中strpos函数的正确使用方式

1783
来自专栏xcywt

关于delete 和 new

关于new和delete,有如下代码 // new_test.cpp #include<iostream> using namespace std; cl...

2036

扫码关注云+社区

领取腾讯云代金券