Ubuntu12.04 urllib2打印时乱码问题
代码如下:
# -*- encoding=utf-8 -*- import urllib2 import sys content = urllib2.urlopen('http://www.douban.com').read() type = sys.getfilesystemencoding() print content print content.decode("UTF-8").encode(type)
打印content的内容就是一堆乱七八糟的东西:��}isI��w�����,U�$��i���o�tOL��{_��)
(���b���q+٭}o˖e��M��E�7!�Eܟb�U��ᝬ*�Ul$��V@-�'3�~2O�--�_����������?�~�������-�CD��tyt��6}����xܣ���,��0+0�����Y���6�t�c
然后decode的时候又报错:UnicodeDecodeError: 'utf8' codec can't decode byte 0x8b in position 1: invalid start byte
系统环境是Ubuntu1204, Python2,7 ,这究竟是什么问题呢?
先谢谢了!
首先你的代码在我这里运行数据显示正常。不过根据你的输出来看,应该不是抓取到网页的编码错误(里面连ascii字符都没有,一般的乱码英文字符还是可以显示出来的)。猜测可能是你的源码文件编码错误。
另外,代码中说明源码文件编码,用coding:
# -*- coding=utf-8 -*-
还有type是内置类型,一般不要把变量名命名为python自带的类型名。
可能是压缩了,看下头里面是不是有 Content-Encoding:xxx
如果是压缩了,需要手动解压,urllib是不会帮你解压的
def unzip(self,data): import gzip import StringIO data = StringIO.StringIO(data) gz = gzip.GzipFile(fileobj=data) data = gz.read() gz.close() return data
很奇怪的问题,你用 logging 打下能否正常输出中文。
# -*- encoding=utf-8 -*- import logging import urllib2 import sys logging.basicConfig(level=logging.INFO) content = urllib2.urlopen('http://www.douban.com').read() logging.info(type(content)) logging.info(content.decode('utf-8'))
玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd20270.html
相关文章 Recommend
- • Python urllib2.Request.add_header() 添加header不成功解决
- • python urllib2中打印处理信息的方法是什么
- • urllib2.urlopen()打开mp3链接报error: [Errno 10054]
- • python运行效率同函数功能有关系吗?
- • django html模板中for标签循环不能打印是什么原因
- • python 3.3.2没有urllib2库吗?
- • Python urllib2读取网页打不开报urllib2.URLError错误
- • python http请求用ihttplib\httplib2\urllib2谁速度最快
- • python新手问httplib和urllib2有哪些不同
- • 参照Python基础教程打印日期源码报NameError什么问
- • Python urllib2.urlopen报错,如何成功执行呢?
- • Pythony方法cmd打印下面这种图要怎么做?
必知PYTHON教程 Must Know PYTHON Tutorials
- • python 解释器
- • python idle
- • python dir函数
- • python 数据类型
- • python type函数
- • python 字符串
- • python 整型数字
- • python 列表
- • python 元组
- • python 字典
- • python 集合
- • python 变量
- • python print
- • python 函数
- • python 类定义
- • python import
- • python help
- • python open
- • python 异常处理
- • python 注释
- • python continue
- • python pass
- • python return
- • python global
- • python assert
- • python if语句
- • python break
- • python for循环
- • python while循环
- • python else/elif
- • lambda匿名函数
必知PYTHON模块 Must Know PYTHON Modules
- • os 模块
- • sys 模块
- • re 正则表达式
- • time 日期时间
- • pickle 持久化
- • random 随机
- • csv 模块
- • logging 日志
- • socket网络通信
- • json模块
- • urlparse 解析URL
- • urllib 模块
- • urllib2 模块
- • robotparser 解析
- • Cookie 模块
- • smtplib 邮件
- • Base64 编码
- • xmlrpclib客户端
- • string 文本
- • Queue 线程安全
- • math数学计算
- • linecache缓存
- • threading多线程
- • sqlite3数据库
- • gzip压缩解压
最新内容 NEWS
- • Python程序员解决棘手问题的常用库
- • 求助关于restfull api接口几个问题
- • qiniu pythonsdk提示ImportError错误求解
- • 问一个关于Hadoop Python中读写文件统计分析
- • 求问str()同__str__原理上有什么不同,分别在
- • 大神帮忙看下20行的python代码,文件io和数
- • python 爬虫爬wiki 报错 [Errno 65] No route to
- • python续点上传问题None bad token...
- • python3环境下文本中超链接出错,要如何修
- • Python环境保存操作思路问题求助
图文精华 RECOMMEND
-
Python程序员解决棘手问题的常用库
-
求问str()同__str__原理上有什么不同
-
scrapy框架里面用link extractor怎么能
-
python {}.fromkeys创建字典append添加操
-
python3 类型Type str doesn't support th
-
python里面为什么系统的时区是东八
热点文章 HOT
- 学习Python有什么好的书籍推荐?
- Python匿名函数 Lambda表达式作用
- Python与Java、C、Ruby、PHP等编程语言有什么
- Python 正则中文网页字符串提取问题
- 如何为实时性应用存取经纬度?django my
- 想用python做个客户端,在二维码登录这个地
- 有让IDE可识别Python函数参数类型的方法吗
- Python字符串转换成列表正则疑问