python乱码小记

    ipython中直接print r.text会出现输出结果诸如:['\xe4\xbd\xa0\xe5\xa5\xbd', '\xe5\x93\x88\xe5\x93\x88', '\xe5\x91\xb5\xe5\x91\xb5']

  因为默认的编码为utf-8,所以要将中文显示,需要你需要:

r.text.decode('utf-8').encode('gbk')##先转码成unicode,再转码成gbk输出
但,此时你还是会失败,所以:

首先你需要执行:

import sys
reload(sys)
sys.setdefaultencoding("utf-8")

否则会出现:

In [15]: print r.text.decode('utf-8').encode('gbk')
---------------------------------------------------------------------------
UnicodeEncodeError                        Traceback (most recent call last)
<ipython-input-15-ee68b5387e3d> in <module>()
----> 1 print r.text.decode('utf-8').encode('gbk')

C:\Python27\lib\encodings\utf_8.pyc in decode(input, errors)
     14
     15 def decode(input, errors='strict'):
---> 16     return codecs.utf_8_decode(input, errors, True)
     17
     18 class IncrementalEncoder(codecs.IncrementalEncoder):

UnicodeEncodeError: 'ascii' codec can't encode characters in position 77-78: ordinal not in range(128)



几天,装scrapy又遇到乱码坑货问题了。

先是用easy_install 装,遇到vc++需要手工安装,然后又是libssl-dev装不上,搜了半天win下好像也没有。然后转战pip,结果又遇到如下报错,无法进行了:

<span style="font-size:18px;">UnicodeEncodeError: 'ascii' codec can't encode character u'\u2588' in position 8: ordinal not in range(128)</span>

然后这样解决了问题:在python的Lib\site-packages文件夹下新建一个sitecustomize.py,内容为:
    # encoding=utf8  
    import sys   
    reload(sys)  
    sys.setdefaultencoding('utf8')   

这样系统在python启动的时候,自行调用该文件,设置系统的默认编码,而不需要每次都手动的加上解决代码,一劳永逸。

另外,pypi中很多软件已经不提供exe了。。只提供tar和whl,whl只能用pip安装,诸如:pip install xxx.whl   easy_install则不行,所以以后就用pip啦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值