Python中文编码那些事


Posted in Python onJune 25, 2014

首先,要明白encode()和decode()的区别

 encode()的作用是将Unicode编码的字符串转换为其他编码格式。

例如: st1.encode("utf-8")  这句话的作用是将Unicode编码的st1编码为utf-8编码的字符串

decode()的作用是把其他编码格式的字符串转换成Unicode编码的字符串。

例如: st2.decode("utf-8") 这句话的作用是将utf-8编码的字符串st2解码为Unicode编码的字符串

第二,除Unicode编码的字符串以外,任何一种编码的字符串要想转换为其他编码格式,必须先解码后编码

非Unicode编码--> Unicode编码-->非Unicode编码

例如,utf-8编码的字符串st想要转换为gbk编码的字符串,必须经过以下步骤:

st=st.decode("utf-8") #解码为Unicode编码

st=st.encode("gbk")  #从Unicode编码编码为gbk编码

第三,我们经常使用的utf-8编码还分为有BOM的和无BOM的。

第四:关于json文件的中文编码。用Python读取Json文件时经常用到json.load()函数,该函数对json文件的格式是有要求的

1)json文件是utf-8 without BOM编码的,那么可以直接用json.load(filename)函数读取json文件的内容

2)json文件是utf-8 with BOM编码的,不能用json.load()函数读取,json.load()不能正确识别

3)json文件时其他编码的,比如gbk, 要把json文件的编码格式作为一个参数传给json.load():

eg. json.load(filename,"gbk")

第五,怎么查看并且设置自己文件的编码呢?

介绍一个个人比较喜欢的工具"Nodtepad++",随便一个软件管家里就与一键安装。

用这个工具你可以方便的查看自己的文件的当前编码,并可以轻松转换成任意其他编码格式

Python 相关文章推荐
Django视图和URL配置详解
Jan 31 Python
Tensorflow 实现修改张量特定元素的值方法
Jul 30 Python
pycharm修改界面主题颜色的方法
Jan 17 Python
对Python 获取类的成员变量及临时变量的方法详解
Jan 22 Python
Python文件打开方式实例详解【a、a+、r+、w+区别】
Mar 30 Python
Django上线部署之IIS的配置方法
Aug 22 Python
python3.7 利用函数os pandas利用excel对文件名进行归类
Sep 29 Python
python ctypes库2_指定参数类型和返回类型详解
Nov 19 Python
Python restful框架接口开发实现
Apr 13 Python
python使用Word2Vec进行情感分析解析
Jul 31 Python
Python 如何解决稀疏矩阵运算
May 26 Python
Pytest中skip skipif跳过用例详解
Jun 30 Python
教你如何在Django 1.6中正确使用 Signal
Jun 22 #Python
python抓取网页时字符集转换问题处理方案分享
Jun 19 #Python
python在linux中输出带颜色的文字的方法
Jun 19 #Python
解决windows下Sublime Text 2 运行 PyQt 不显示的方法分享
Jun 18 #Python
win7 下搭建sublime的python开发环境的配置方法
Jun 18 #Python
Python写的贪吃蛇游戏例子
Jun 16 #Python
Python中的yield浅析
Jun 16 #Python
You might like
深入php define()函数以及defined()函数的用法详解
2013/06/05 PHP
php阿拉伯数字转中文人民币大写
2015/12/21 PHP
thinkPHP实现多字段模糊匹配查询的方法
2016/12/01 PHP
php+mysql+jquery实现日历签到功能
2017/02/27 PHP
PHP CURL与java http使用方法详解
2018/01/26 PHP
js过滤数组重复元素的方法
2010/09/05 Javascript
常用js字符串判断方法整理
2013/10/18 Javascript
让JavaScript的Alert弹出框失效的方法禁止弹出警告框
2014/09/03 Javascript
javascript每日必学之继承
2016/02/23 Javascript
学习使用bootstrap3栅格系统
2016/04/12 Javascript
js实现千分符和保留几位小数的简单实例
2016/08/01 Javascript
AngularJS指令用法详解
2016/11/02 Javascript
微信小程序 生命周期和页面的生命周期详细介绍
2017/01/19 Javascript
简单快速的实现js计算器功能
2017/08/17 Javascript
Django中使用jquery的ajax进行数据交互的实例代码
2017/10/15 jQuery
浅谈Postman解决token传参的问题
2018/03/31 Javascript
Nodejs Express 通过log4js写日志到Logstash(ELK)
2018/08/30 NodeJs
Vue动画事件详解及过渡动画实例
2019/02/09 Javascript
vue实现移动端项目多行文本溢出省略
2020/07/29 Javascript
[45:44]完美世界DOTA2联赛PWL S2 FTD vs PXG 第一场 11.27
2020/12/01 DOTA
Python2中文处理纪要的实现方法
2018/03/10 Python
Python(TensorFlow框架)实现手写数字识别系统的方法
2018/05/29 Python
python批量修改文件夹及其子文件夹下的文件内容
2019/03/15 Python
Django框架视图函数设计示例
2019/07/29 Python
python中return的返回和执行实例
2019/12/24 Python
在win64上使用bypy进行百度网盘文件上传功能
2020/01/02 Python
如何用Lucene索引数据库
2016/02/23 面试题
测试时代收集的软件测试面试题
2013/09/25 面试题
物业保安主管岗位职责
2013/12/25 职场文书
根叔历年演讲稿
2014/05/20 职场文书
医学检验专业自荐信
2014/09/18 职场文书
法定代表人身份证明书(含说明)
2014/10/02 职场文书
婚礼父母答谢词
2015/01/04 职场文书
2016春季小学开学寄语
2015/12/03 职场文书
2016入党培训心得体会范文
2016/01/08 职场文书
《雪域豹影》读后感:父爱的伟大
2019/12/23 职场文书