码迷,mamicode.com
首页 > 编程语言 > 详细

python编码问题

时间:2017-11-30 23:27:14      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:default   port   oca   def   decode   nbsp   技术   直接   实现   

编码问题真是恼人,整理理解一下。

 

linux:vim 下set fileencoding

python中的chardet检测包

import chardet

f = open(file,r)
fencoding=chardet.detect(f.read())
print fencoding

了解python中str的编码后可以利用decode和encode来实现编码的转换。

一般流程是str利用decode方法根据str的编码将其解码为unicode字符串类型,然后利用encode根据特定的编码将unicode字符串类型转换为特定的编码。python中str和unicode属于两种不同的类型,如下。

技术分享图片

一般情况下window默认编码gbk,linux默认编码utf8

python编程中 系统编码,python编码,文件编码 的概念。

系统编码:默认写源码的编辑器的编码方式。它代表源码文件内的所有内容都是根据词方式编码成二进制码流。存入到磁盘中的。linux下通过locale命令查看。

python编码:指python内设置的解码方式。如果不设定的话,python默认的是ascii解码方式。如果python源代码文件中不出现中文的话,这个地方怎么设定应该不会问题。

设定方法:在源码文件开头(一定是第一行):#-*-coding:UTF-8-*-,源码文件的设置解码方式是UTF-8 或者

import sys
reload(sys)
sys.setdefaultencoding(UTF-8)

文件编码:文本的编码方式,linux下vim利用set fileencoding查看。

一般情况下输出乱码的原因就是 没有按照系统解码的方式进行编码。
比如print s, s类型为str,linux系统下系统默认编码为utf8编码,s在输出前就应该编码为utf8。如果s为gbk编码就应该这样输出。print s.decode(‘gbk‘).encode(‘utf8‘)才能输出中文。

window下面情况相同,window默认编码为gbk编码,所以s输出前必须编码为gbk。

python处理中一般处理unicode类型。这样输出前直接编码即可。

 

python编码问题

标签:default   port   oca   def   decode   nbsp   技术   直接   实现   

原文地址:http://www.cnblogs.com/maplered/p/7931919.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!