Python2中文处理纪要的实现方法


Posted in Python onMarch 10, 2018

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");

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python sqlite3事务处理方法实例分析
Jun 19 Python
Python中函数eval和ast.literal_eval的区别详解
Aug 10 Python
Python实现曲线拟合操作示例【基于numpy,scipy,matplotlib库】
Jul 12 Python
Python解决线性代数问题之矩阵的初等变换方法
Dec 12 Python
python解析yaml文件过程详解
Aug 30 Python
python带参数打包exe及调用方式
Dec 21 Python
selenium中get_cookies()和add_cookie()的用法详解
Jan 06 Python
浅谈Pytorch torch.optim优化器个性化的使用
Feb 20 Python
python获取响应某个字段值的3种实现方法
Apr 30 Python
python 双循环遍历list 变量判断代码
May 04 Python
pytorch加载自己的图像数据集实例
Jul 07 Python
解决redis与Python交互取出来的是bytes类型的问题
Jul 16 Python
python实现冒泡排序算法的两种方法
Mar 10 #Python
Python使用pyh生成HTML文档的方法示例
Mar 10 #Python
tensorflow获取变量维度信息
Mar 10 #Python
TensorFlow变量管理详解
Mar 10 #Python
TensorFlow神经网络优化策略学习
Mar 09 #Python
TensorFlow实现AutoEncoder自编码器
Mar 09 #Python
TensorFlow实现MLP多层感知机模型
Mar 09 #Python
You might like
如何用PHP来实现一个动态Web服务器
2015/07/29 PHP
PHP简单实现冒泡排序的方法
2016/12/26 PHP
JS的递增/递减运算符和带操作的赋值运算符的等价式
2007/12/08 Javascript
Js动态创建div
2008/09/25 Javascript
JavaScript 设计模式学习 Factory
2009/07/29 Javascript
关于jQuery中的end()使用方法
2011/07/10 Javascript
jQuery替换字符串(实例代码)
2013/11/13 Javascript
Javascript window对象详解
2014/11/12 Javascript
jQuery中clone()方法用法实例
2015/01/16 Javascript
微信小程序 form组件详解及简单实例
2017/01/10 Javascript
自带气泡提示的vue校验插件(vue-verify-pop)
2017/04/07 Javascript
JavaScript箭头函数_动力节点Java学院整理
2017/06/28 Javascript
node.js支持多用户web终端实现及安全方案
2017/11/29 Javascript
使用electron实现百度网盘悬浮窗口功能的示例代码
2018/10/24 Javascript
Layui实现带查询条件的分页
2019/07/27 Javascript
解决layui数据表格排序图标被超出的表头挤出去的问题
2019/09/19 Javascript
Vue项目打包编译优化方案
2020/09/16 Javascript
[01:12](回顾)DOTA2国际邀请赛,全世界DOTAer的盛宴
2014/07/01 DOTA
python绘制简单折线图代码示例
2017/12/19 Python
Python中if elif else及缩进的使用简述
2018/05/31 Python
通过python顺序修改文件名字的方法
2018/07/11 Python
python操作excel让工作自动化
2019/08/09 Python
python如何导出微信公众号文章方法详解
2020/08/31 Python
python实现模拟器爬取抖音评论数据的示例代码
2021/01/06 Python
CSS3弹性伸缩布局之box布局
2016/07/12 HTML / CSS
字中字效果的实现【html5实例】
2016/05/03 HTML / CSS
中国第一家杂志折扣订阅网:杂志铺
2016/08/30 全球购物
elf彩妆英国官网:e.l.f. Cosmetics英国(美国平价彩妆品牌)
2017/11/02 全球购物
如何查询Oracle数据库中已经创建的索引
2013/10/11 面试题
函授教育个人学习的自我评价
2013/12/31 职场文书
七一党建活动方案
2014/01/28 职场文书
优秀团员个人事迹材料
2014/01/29 职场文书
优秀德育工作者事迹材料
2014/05/07 职场文书
普通党员对照检查材料
2014/08/28 职场文书
诚信考试主题班会
2015/08/17 职场文书
Nginx本地目录映射实现代码实例
2021/03/31 Servers