Python爬虫爬取煎蛋网图片代码实例


Posted in Python onDecember 16, 2019

这篇文章主要介绍了Python爬虫爬取煎蛋网图片代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

今天,试着爬取了煎蛋网的图片。

用到的包:

  • urllib.request
  • os

分别使用几个函数,来控制下载的图片的页数,获取图片的网页,获取网页页数以及保存图片到本地。过程简单清晰明了

直接上源代码:

import urllib.request
import os


def url_open(url):
  req = urllib.request.Request(url)
  req.add_header('user-agent','Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36')
  response = urllib.request.urlopen(url)
  html = response.read()

  return html

def get_page(url):
  html = url_open(url).decode('utf-8')

  a = html.find('current-comment-page')+23
  b = html.find(']',a)

  return html[a:b]


def find_imgs(url):
  html = url_open(url).decode('utf-8')
  img_addrs = []

  a = html.find('img src=')

  while a != -1:
    b = html.find('.jpg',a ,a+255)
    if b != -1:
      img_addrs.append('https:'+html[a+9:b+4]) # 'img src='为9个偏移 '.jpg'为4个偏移
    else:
      b = a+9
    a = html.find('img src=', b)

  return img_addrs


def save_imgs(folder, img_addrs):
  for each in img_addrs:
    filename = each.split('/')[-1]
    with open(filename, 'wb') as f:
      img = url_open(each)
      f.write(img)
    print(img_addrs)

def download_mm(folder = 'xxoo', pages = 5):
  os.mkdir(folder)
  os.chdir(folder)

  url = 'http://jandan.net/ooxx/'
  page_num = int(get_page(url))

  for i in range(pages):
    page_num -= i
    page_url = url + 'page-'+ str(page_num) + '#comments'
    img_addrs = find_imgs(page_url)
    save_imgs(folder, img_addrs)

if __name__ == '__main__':
  download_mm()

其中在主函数download_mm()中,将pages设置在了5面。

本来设置的是10,但是在程序执行的过程中。出现了404ERROR错误

即imgae_url出现了错误。尝试着在save_img()函数中加入了测试代码:print(img_addrs),

Python爬虫爬取煎蛋网图片代码实例

想到会不会是因为后面页数的图片,img_url的格式出现了改变,导致404,所以将pages改成5,

再次运行,结果没有问题,图片能正常下载:

Python爬虫爬取煎蛋网图片代码实例

仔细观察发现,刚好是在第五面的图片往后,出现了不可下载的问题(404)。所以在煎蛋网上,我们直接跳到第6面查看图片的url。

Python爬虫爬取煎蛋网图片代码实例

上图是后5面的图片url,下图是前5面的图片url

Python爬虫爬取煎蛋网图片代码实例

而源代码中,寻找的图片url为使用find()函数,进行定为<img src=‘'> <.jpg>中的图片url,所以后5面出现的a href无法匹配,即出现了404 ERROR。如果想要下载后续的图片,需要重新添加一个url定位

即在find中将 img src改成 a href,偏移量也需要更改。

总结:

使用find()来定位网页标签确实太过low,所以以后在爬虫中要尽量使用正则表达式和Beautifulsoup包来提高效率,而这两项我还不是特别熟,所以需要更多的训练。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用Python编写一个简单的tic-tac-toe游戏的教程
Apr 16 Python
学习python中matplotlib绘图设置坐标轴刻度、文本
Feb 07 Python
Python中列表与元组的乘法操作示例
Feb 10 Python
深入理解Python 关于supper 的 用法和原理
Feb 28 Python
python指定写入文件时的编码格式方法
Jun 07 Python
python实现指定字符串补全空格、前面填充0的方法
Nov 16 Python
python判断字符串或者集合是否为空的实例
Jan 23 Python
python中数据库like模糊查询方式
Mar 02 Python
python实现提取COCO,VOC数据集中特定的类
Mar 10 Python
超全Python图像处理讲解(多模块实现)
Apr 13 Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
Dec 08 Python
Python文件的操作示例的详细讲解
Apr 08 Python
python实现监控阿里云账户余额功能
Dec 16 #Python
Python实现密码薄文件读写操作
Dec 16 #Python
如何基于Python实现电子邮件的发送
Dec 16 #Python
Python如何基于selenium实现自动登录博客园
Dec 16 #Python
Python正则表达式急速入门(小结)
Dec 16 #Python
如何基于Python制作有道翻译小工具
Dec 16 #Python
django框架单表操作之增删改实例分析
Dec 16 #Python
You might like
php不用正则采集速度探究总结
2008/03/24 PHP
PHP实现仿Google分页效果的分页函数
2015/07/29 PHP
利用PHPStorm如何开发Laravel应用详解
2017/08/30 PHP
5个javascript的数字格式化函数分享
2011/12/07 Javascript
基于jquery的禁用右键、文本选择功能、复制按键的实现代码
2013/08/27 Javascript
jQuery1.9.1源码分析系列(十六)ajax之ajax框架
2015/12/04 Javascript
AngularJS中的JSONP实例解析
2016/12/01 Javascript
bootstrapValidator表单验证插件学习
2016/12/30 Javascript
canvas实现绘制吃豆鱼效果
2017/01/12 Javascript
AngulaJS路由 ui-router 传参实例
2017/04/28 Javascript
详解require.js配置路径的用法和css的引入
2017/09/06 Javascript
javascript 代码是如何被压缩的示例代码
2020/05/06 Javascript
解决vue init webpack 下载依赖卡住不动的问题
2020/11/09 Javascript
[36:17]DOTA2上海特级锦标赛 - VGL音乐会全集
2016/03/06 DOTA
[01:06:30]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第二场 1月9日
2021/03/11 DOTA
python中 ? : 三元表达式的使用介绍
2013/10/09 Python
Python基于Socket实现的简单聊天程序示例
2017/08/05 Python
python语言基本语句用法总结
2019/06/11 Python
Ubuntu下Anaconda和Pycharm配置方法详解
2019/06/14 Python
用Python在Excel里画出蒙娜丽莎的方法示例
2020/04/28 Python
基于Python的一个自动录入表格的小程序
2020/08/05 Python
Python+OpenCV图像处理——图像二值化的实现
2020/10/24 Python
HTML5探秘:用requestAnimationFrame优化Web动画
2018/06/03 HTML / CSS
南非最受欢迎的时尚品牌:MRP
2016/09/18 全球购物
整个世界的设计师家具在哈恩:Designathome
2019/03/25 全球购物
澳大利亚二手奢侈品网站:Modsie
2019/09/23 全球购物
幼儿园教学随笔感言
2014/02/23 职场文书
机械设计专业大学生职业生涯规划书范文
2014/09/13 职场文书
小学趣味运动会加油稿
2014/09/25 职场文书
2014年局领导班子自身建设情况汇报
2014/11/21 职场文书
超强台风观后感
2015/06/09 职场文书
青春雷锋观后感
2015/06/10 职场文书
国家助学金受助感言
2015/08/01 职场文书
面试被问select......for update会锁表还是锁行
2021/11/11 MySQL
Go并发4种方法简明讲解
2022/04/06 Golang
python APScheduler执行定时任务介绍
2022/04/19 Python