Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 52086|回复: 0

python抓取中文网页乱码通用解决方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-8 20:56:58 | 显示全部楼层 |阅读模式

    注:转载自http://www.cnpythoner.com/

    我们经常通过python做采集网页数据的时候,会碰到一些乱码问题,今天给大家分享一个解决网页乱码,尤其是中文网页的通用方法。

    首页我们需要安装chardet模块,这个可以通过easy_install 或者pip来安装。

    安装完以后我们在控制台上导入模块,如果正常就可以。

    比如我们遇到的一些ISO-8859-2也是可以通过下面的方法解决的。

    直接上代码吧:

    import urllib2
    import sys
    import chardet

    req = urllib2.Request( "http://www.163.com/") ##这里可以换成http://www.baidu.com,http://www.sohu.com
    content = urllib2.urlopen(req).read()
    typeEncode = sys.getfilesystemencoding() ##系统默认编码
    infoencode = chardet.detect(content).get( 'encoding', 'utf-8') ##通过第3方模块来自动提取网页的编码
    html = content.decode(infoencode, 'ignore').encode(typeEncode) ##先转换成unicode编码,然后转换系统编码输出
    print html

     通过上面的代码,相信能够解决你采集乱码的问题。

    接着开始学习网络爬虫的深入点儿的东东:

    以抓取韩寒博客文章目录来加以说明:http://blog.sina.com.cn/s/articlelist_1191258123_0_1.html,下面是截图

    我用的是Chrome浏览器(firefox也行),打开上述网页,鼠标右击,选择审查元素,就会出现下面所示

    首先我们来实现抓取第一篇文章“一次告别”的page的url

    按住ctrl+f就会在上图左下角打开搜索栏,输入”一次告别“,就会自动定位到html源码所在位置,如上高亮显示的地方

    接下来我们就是要把对应的url:http://blog.sina.com.cn/s/blog_4701280b0102ek51.html提取出来

    详细实现代码如下:

     1 #coding:utf-8
     2 import urllib
     3 str0 = '<a title="一次告别" target="_blank" href="http://blog.sina.com.cn/s/blog_4701280b0102ek51.html">一次告别</a>'
     4 title = str0.find(r'<a title')
     5 print title
     6 href = str0.find(r'href=')
     7 print href
     8 html = str0.find(r'.html')
     9 print html
    10 url = str0[href + 6:html + 5]
    11 print url
    12 content = urllib.urlopen(url).read()
    13 #print content
    14 filename = url[-26:]
    15 print filename
    16 open(filename, 'w').write(content)
    catchBlog.py

    下面对代码进行解释:

     首先利用find函数开始依次匹配查找'<a title','href=','.html',这样就可以找到关键字符所在的索引位置,然后就可以定位到http://blog.sina.com.cn/s/blog_4701280b0102ek51.html的位置[href+6:html+5]
    最后利用urllib的相关函数打开并读取网页内容,写到content中

    运行程序:

    0
    40
    93
    http://blog.sina.com.cn/s/blog_4701280b0102ek51.html
    blog_4701280b0102ek51.html

    于是在代码所在目录生成html文件blog_4701280b0102ek51.html

    至此便抓取到第一篇文章的url及网页内容;上述操作主要学习了以下几个内容:1.分析博客文章列表特征2.提取字符串中的网络连接地址3.下载博文到本地

    接下来继续深入:获取博文目录第一页所有文章的链接并将所有文章下载下来

     1 #coding:utf-8
     2 import urllib
     3 import time
     4 url = ['']*50
     5 con = urllib.urlopen('http://blog.sina.com.cn/s/articlelist_1191258123_0_1.html').read()
     6 i = 0
     7 title = con.find(r'<a title=')
     8 href = con.find(r'href=', title)
     9 html = con.find(r'.html', href)
    10 
    11 while title != -1 and href != -1 and html != -1 and i < 50:
    12     url = con[href+6:html+5]
    13     print url
    14     title = con.find(r'<a title=', html)
    15     href = con.find(r'href=', title)
    16     html = con.find(r'.html', href)
    17     i = i + 1
    18 else:
    19     print "Find end!"
    20 j = 0
    21 while j < 50:
    22     content = urllib.urlopen(url[j]).read()
    23     open(r'hanhan/' + url[j][-26:], 'w+').write(content)
    24     j = j + 1
    25     print 'downloading', url[j]
    26     time.sleep(15)
    27 else:
    28     print 'Download article finish!'
    29 #print 'con', con
    catchBlog1.py

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-21 15:35 , Processed in 0.066687 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表