入门十天,我就用50行Python代码爬到了整个网站

news/2024/5/9 21:16:01/文章来源:https://blog.csdn.net/weixin_44099558/article/details/85090816

 

这篇文章是利用aiohttp这个库来进行说明的。

如果爬虫需要展现速度,我觉得就是去下载图片吧,原本是想选择去煎蛋那里下载图片的,那里的美女图片都是高质量的,我稿子都是差不多写好了的,无奈今天重新看下,妹子图的入口给关了,至于为什么关呢,大家可以去看看昨天好奇心日报的关停原因吧或者百度下,这里就不多说了,这次我选择了去下载无版权高清图片,因为做自媒体的人很怕侵权,找无版权的图片仿佛成了日常工作,所以这次我选择了这个网站。

学习Python中有不明白推荐加入交流裙
                号:735934841
                群里有志同道合的小伙伴,互帮互助,
                群里有免费的视频学习教程和PDF!

 

 

那下面来看看使用异步以及不使用异步的差别?

 

 

 

(右边是使用异步的,左边是没有使用异步的,由于用于测试,所以选择下载12张图片即可)

可以看到,在使用异步之后运行的时间比不使用异步的程序少了差不多6倍的时间,是不是感觉到high了起来?那我们分析下怎样爬取吧。

1.找目标网页

这个网站首页就有一堆图片,而且往下拉时还会自动刷新,很明显是个ajax加载,但不怕,动态加载这东西我们之前讲过了,所以打开开发者工具看下是怎样的请求吧。

 

 

 

 

 

 

往下拉的时候很容易看到这个请求,这个是一个get请求,状态码为200,网址为网页链接photos?page=3&per_page=12&order_by=latest,有三个参数,很容易知道page参数就是页,这个参数是变化的,其他的参数都是不变的。

 

 

 

返回来的内容是个json类型,里面的links下的download就是我们图片下载的链接,现在所有东西都清楚了,那下面就是代码了。

2.代码部分

async def __get_content(self, link):

async with aiohttp.ClientSession as session:

response = await session.get(link)

content = await response.read

return content

这个是获取图片的内容的方法,aiohttpClientSession和requests.session的用法是差不多,只不过获取unicode编码的方法变成了read

下面是完整代码

import requests, os, time

import aiohttp, asyncio

class Spider(object):

def __init__(self):

self.headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99Safari/537.36'}

self.num = 1

if '图片' not in os.listdir('.'):

os.mkdir('图片')

self.path = os.path.join(os.path.abspath('.'), '图片')

os.chdir(self.path) # 进入文件下载路径

async def __get_content(self, link):

async with aiohttp.ClientSession as session:

response = await session.get(link)

content = await response.read

return content

def __get_img_links(self, page):

url = '网页链接photos'

data = {

'page': page,

'per_page': 12,

'order_by': 'latest'

}

response = requests.get(url, params=data)

if response.status_code == 200:

return response.json

else:

print('请求失败,状态码为%s' % response.status_code)

async def __download_img(self, img):

content = await self.__get_content(img[1])

with open(img[0]+'.jpg', 'wb') as f:

f.write(content)

print('下载第%s张图片成功' % self.num)

self.num += 1

def run(self):

start = time.time

for x in range(1, 101): # 下载一百页的图片就可以了,或者自己更改页数

links = self.__get_img_links(x)

tasks = [asyncio.ensure_future(self.__download_img((link['id'], link['links']['download']))) for link in links]

loop = asyncio.get_event_loop

loop.run_until_complete(asyncio.wait(tasks))

if self.num >= 10: # 测试速度使用,如需要下载多张图片可以注释这段代码

break

end = time.time

print('共运行了%s秒' % (end-start))

def main:

spider = Spider

spider.run

if __name__ == '__main__':

main

可以看到不到50行的代码就可以把整个网网站的图片下载下来了,不得不吹一下python的强大~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_841255.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

教你用Python访问一零二四网站,拒绝伸手党

学习Python中有不明白推荐加入交流裙 号:735934841 群里有志同道合的小伙伴,互帮互助, 群里有免费的视频学习教程和PDF! 我感觉这个虫子全网***最方便***,最牛逼&…

linux 内核 中断,工作队列 - Linux内核学习之中断_Linux教程_Linux公社-Linux系统门户网站...

[概述]工作队列是一种将工作推后执行的的形式,工作队列可以把工作推后,交由一个内核线程去执行,占有进程上下文的所有优势,允许重新调度和睡眠。[工作队列的实现]工作队列子系统是一个用于创建内核线程的接口,通过它创…

学习Python你不去8个网站?逗我呢!

作为一个现时代的程序员初学者,除了看书之外,互联网的学习手段也是断不能少的! 以下这些网站,虽说不上全方位的满足你的需求,但是大部分也都能! 0.国外的大神GitHub : https://github.com/pyp…

c++安装 ttf字体_良心网站!45款免费可商用字体大合集下载,再也不怕版权侵扰了!...

100font 是一个免费可商用字体收集网站,上面列出了 目前45 款可以商用的免费字体,看名字,相信未来要收集到 100 款免费字体为止。网站传送门https://www.100font.com/字体打包下载地址【 完 整 版 】百度网盘:https://pan.baidu.c…

如何创建一个模块_如何用手机创建一个网站

如何用手机创建网站?其实正确的说法是如何创建一个手机网站才对,因为很难用手机去制作网站,很不方便。一般是用电脑模拟手机去建网站。我们知道现在很多人上网都是通过手机上网,所以我们自己建网站时,也要学会创建手机…

Python快速刷题网站——牛客网 数据分析篇(一)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(二)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(三)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(四)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(五)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(六)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(七)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(八)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(九)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(十)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

Python快速刷题网站——牛客网 数据分析篇(十一)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

猿创征文|Python快速刷题网站——牛客网 数据分析篇(十二)

👦👦一个帅气的boy,你可以叫我Love And Program 🖱 ⌨个人主页:Love And Program的个人主页 💖💖如果对你有帮助的话希望三连💨💨支持一下博主 python是目前非常火爆的…

怎么让网站在浏览器网址前面显示小图标?

大家在浏览很多网站的时候都会发现在浏览器的地址栏前面会有一个小图标,在浏览器的标签位置也有一个小图标,例如 Baidu 、腾讯等网站都有这样的图标。你的网站上想不想也增加一个这样的小图标呢?有了这个小图标你的网站就会比别人的网站更加醒…

网站首页滚动图片的后台管理

在网上找了好久的资源都没有找到,怎么实现在后台可以更换网站图片的,因为是在做项目,最后项目要交给,不 太懂计算机的管理员来管理, 这样就涉及到了,怎么让网站的管理员可以定期更换滚动的图片&#xff0c…

Java实现视频网站的视频上传、视频转码、视频关键帧抽图, 及视频播放功能

视频网站中提供的在线视频播放功能,播放的都是FLV格式的文件,它是Flash动画文件,可通过Flash制作的播放器来播放该文件.项目中用制作的player.swf播放器. 多媒体视频处理工具FFmpeg有非常强大的功能包括视频采集功能、视频格式转换、视频抓图、给视频加水印等。 ffmpeg视频…