【爬虫实战】手把手教你用Python爬取某图网4000张图片

254 篇文章 8 订阅
9 篇文章 0 订阅

在这里插入图片描述

相信很多设计小伙伴有好的灵感,但是没有好的设计素材,今天它来了。摄图网4000张设计素材,取之不尽,如下图所示:
在这里插入图片描述
好了,废话不多说,开始用Python采集。

01需求分析

采集摄图网的素材图片,目标网址–>请求数据–>解析数据–>提取数据–>保存数据。

02技术栈

首先我们用到的技术包括:urllib,requests,bs4等。

03采集流程

加粗样式

1、分析网页结构

打开网址:https://699pic.com/paihang/tupian.html,分析网页结构,我们可以看到首页图片数据杂论,这里我们爬取的是"今日热门"的图片,点击发现更多:来到目标页面,拖动滚轮滑到底部,发现有40个分页,也就是我们今天要爬取的4000张设计图片:
在这里插入图片描述

2、发起请求

接着对列表中的每一条url进行遍历,然后发起请求:

for url in urllist: 
    resp = requests.get(url,headers=hd) 
    html = resp.content.decode('utf-8') 

3、数据解析

得到了一个html对象,爬取页面数据信息后,需要对页面进行解析,这里我使用到的解析库是bs4(偏爱),当然xpath也是可以的。通过分析页面元素,我们发现每个翻页里面的图片都有这样的规律:
在这里插入图片描述
因此可以通过bs4的select方法抓取所有class='lazy’的img标签,得到一个列表,然后通过测试发现图片的链接存放在img标签的data-original属性里,通过img.attrs[‘data-original’]得到,再与’https:'进行字符串拼接,得到完整图片链接。

	for img in imgs: 
	           img_url = img.attrs['data-original'] 
	           total_url = base_http_str + img_url 
	           print(total_url) 
	           # print('--'*60) 
	           imgurllist.append(total_url) 

4.提取保存数据

最后运用urllib中的urlretrive方法,把图片保存到本地。

def writeData(imgurllist): 
    for index,url in enumerate(imgurllist): 
        urllib.request.urlretrieve(url,'image/'+ '%s.png'%index) 
        print('第%s张图片下载完成'%index) 

04运行爬虫

运行爬虫代码,效果如下:
在这里插入图片描述
图片就下载完成了,不过运用传统方法有点慢,下次试试多线程,提升爬虫效率。

燃烧秀发输出内容,如果有一丢丢收获,点个赞鼓励一下吧!

最后

在这里插入图片描述
上面是我收集整理的一些资料,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你。

如果你已经工作但是经常觉得难点很多,觉得自己测试方面学的不够精想要继续学习的,想转行怕学不会的, 都可以加入我们1033482984,群内可领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!微信公众号【软件测试小dao

好文分享,希望能帮助到你们。

软件测试工程师应该如何提高自己的技能?送给迷茫的你(共勉)

全员编程的时代,你是否坚持不下去了?送给迷茫的你

面试简历实战不会写?进来手把手教你搞定

腾讯10年测试经验!推荐给测试工程师的50篇书籍!【建议收藏反复观看】

“小故事,大道理”,分享给现在处于迷茫中的你们【深有感悟】

  • 45
    点赞
  • 201
    收藏
    觉得还不错? 一键收藏
  • 32
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 32
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值