python抓取并保存html页面时乱码问题的解决方法


Posted in Python onJuly 01, 2016

本文实例讲述了python抓取并保存html页面时乱码问题的解决方法。分享给大家供大家参考,具体如下:

在用Python抓取html页面并保存的时候,经常出现抓取下来的网页内容是乱码的问题。出现该问题的原因一方面是自己的代码中编码设置有问题,另一方面是在编码设置正确的情况下,网页的实际编码和标示的编码不符合造成的。html页面标示的编码在这里:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

这里提供一种简单的办法解决:使用chardet判断网页的真实编码,同时从url请求返回的info判断标示编码。如果两种编码不同,则使用bs模块扩展为GB18030编码;如果相同则直接写入文件(这里设置系统默认编码为utf-8)。

import urllib2
import sys
import bs4
import chardet
reload(sys)
sys.setdefaultencoding('utf-8')
def download(url):
  htmlfile = open('test.html','w')
  try:
    result = urllib2.urlopen(url)
    content = result.read()
    info = result.info()
    result.close()
  except Exception,e:
    print 'download error!!!'
    print e
  else:
    if content != None:
      charset1 = (chardet.detect(content))['encoding'] #real encoding type
      charset2 = info.getparam('charset') #declared encoding type
      print charset1,' ', charset2
      # case1: charset is not None.
      if charset1 != None and charset2 != None and charset1.lower() != charset2.lower():
        newcont = bs4.BeautifulSoup(content, from_encoding='GB18030')  #coding: GB18030
        for cont in newcont:
          htmlfile.write('%s\n'%cont)
      # case2: either charset is None, or charset is the same.
      else:
        #print sys.getdefaultencoding()
        htmlfile.write(content) #default coding: utf-8
  htmlfile.close()
if __name__ == "__main__":
  url = 'https://3water.com'
  download(url)

得到的test.html文件打开如下,可以看到使用的是UTF-8无BOM编码格式存储的,也就是我们设置的默认编码:

python抓取并保存html页面时乱码问题的解决方法

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
pycharm 使用心得(一)安装和首次使用
Jun 05 Python
python中函数总结之装饰器闭包详解
Jun 12 Python
python实现冒泡排序算法的两种方法
Mar 10 Python
pandas使用get_dummies进行one-hot编码的方法
Jul 10 Python
我喜欢你 抖音表白程序python版
Apr 07 Python
python命令行工具Click快速掌握
Jul 04 Python
python切片(获取一个子列表(数组))详解
Aug 09 Python
Python使用get_text()方法从大段html中提取文本的实例
Aug 27 Python
python numpy 反转 reverse示例
Dec 04 Python
TensorFlow2.X使用图片制作简单的数据集训练模型
Apr 08 Python
Python中使用aiohttp模拟服务器出现错误问题及解决方法
Oct 31 Python
Python语言内置数据类型
Feb 24 Python
python处理html转义字符的方法详解
Jul 01 #Python
python简单读取大文件的方法
Jul 01 #Python
python编码总结(编码类型、格式、转码)
Jul 01 #Python
Python编码类型转换方法详解
Jul 01 #Python
Python面向对象编程中关于类和方法的学习笔记
Jun 30 #Python
Python中的time模块与datetime模块用法总结
Jun 30 #Python
详解Swift中属性的声明与作用
Jun 30 #Python
You might like
Zend Framework 2.0事件管理器(The EventManager)入门教程
2014/08/11 PHP
简单实用的PHP防注入类实例
2014/12/05 PHP
javascript+php实现根据用户时区显示当地时间的方法
2015/03/11 PHP
php中get_defined_constants函数用法实例分析
2015/05/12 PHP
PHP获取客户端及服务器端IP的封装类
2016/07/21 PHP
php使用Jpgraph创建3D饼形图效果示例
2017/02/15 PHP
CMSPRESS 10行代码搞定 PHP无限级分类2
2018/03/30 PHP
PHP实现通过二维数组键值获取一维键名操作示例
2019/10/11 PHP
在一个form用一个SUBMIT(或button)分别提交到两个处理表单页面的代码
2007/02/15 Javascript
JavaScript 学习笔记二 字符串拼接
2010/03/28 Javascript
SwfUpload在IE10上不出现上传按钮的解决方法
2013/06/25 Javascript
js判断60秒以及倒计时示例代码
2014/01/24 Javascript
jQuery实现动画效果的简单实例
2014/01/27 Javascript
extjs_02_grid显示本地数据、显示跨域数据
2014/06/23 Javascript
解决jQuery上传插件Uploadify出现Http Error 302错误的方法
2015/12/18 Javascript
javascript实现PC网页里的拖拽效果
2016/03/14 Javascript
原生JS:Date对象全面解析
2016/09/06 Javascript
老生常谈原生JS执行环境与作用域
2016/11/22 Javascript
Vue.js实现一个SPA登录页面的过程【推荐】
2017/04/29 Javascript
JS运动特效之同时运动实现方法分析
2018/01/24 Javascript
详解es6新增数组方法简便了哪些操作
2019/05/09 Javascript
微信小程序如何再次获取用户授权的方法
2019/05/10 Javascript
VUE 组件转换为微信小程序组件的方法
2019/11/06 Javascript
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
2021/03/01 Vue.js
Python 错误和异常小结
2013/10/09 Python
python使用插值法画出平滑曲线
2018/12/15 Python
Python3+selenium实现cookie免密登录的示例代码
2020/03/18 Python
python实现贪吃蛇游戏源码
2020/03/21 Python
HTML5 CSS3实现一个精美VCD包装盒个性幻灯片案例
2014/06/16 HTML / CSS
Peter Millar官网:美国高档生活服饰品牌
2018/07/02 全球购物
酒店门卫岗位职责
2013/12/29 职场文书
科级干部群众路线教育实践活动对照检查材料思想汇报
2014/09/20 职场文书
防灾减灾标语
2014/10/07 职场文书
学校机关党总支领导班子整改工作方案
2014/10/26 职场文书
乡镇党的群众路线教育实践活动制度建设计划
2014/11/03 职场文书
图解排序算法之希尔排序Java实现
2021/06/26 Java/Android