Python爬虫(6)-selenium用requests、wget、urllib3这3种方法搞定图片和PDF文件下载

在这里插入图片描述
之前的文章有关于更多操作方式详细解答,本篇基于前面的知识点进行操作,如果不了解可以先看之前的文章
Python爬虫(1)一次性搞定Selenium(新版)8种find_element元素定位方式
Python爬虫(2)-Selenium控制浏览器
Python爬虫(3)-Selenium结合pywin32模拟键盘操作
Python爬虫(4)-Selenium模拟鼠标操作

Python爬虫(5)-selenium用显式等待、隐式等待、强制等待,解决反复爬取网页时无法定位元素问题

selenium下载图片和PDF的文件的方式有很多种,可以使用自带的下载方式,也可以使用模拟鼠标右键点击的方式去储存和下载不过这两种方式都不太推荐使用,因为我们的使用

selenium的目的主要是为了做一些爬虫,爬虫多数时候需要下载大量的图片和文件,这里就需要使用其他的方式来进行下载文件

Python爬虫(6)-selenium用requests、wget、urllib3、Boto3、asyncio5种方法搞定图片和PDF文件下载

下载前的工作,需要定位好图片的地址
在这里插入图片描述
完成定位之后我们需要获取到图片的地址也就是src

from selenium import webdriver
from selenium.webdriver import Chrome, ChromeOptions
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
opt = ChromeOptions()            # 创建Chrome参数对象
opt.headless = False            # 把Chrome设置成可视化无界面模式,windows/Linux 皆可
driver = Chrome(options=opt)
driver.get('https://www.pexels.com/zh-cn/photo/931177/')
ab = driver.find_element(By.XPATH,'//*[@id="__next"]/main/div/div[2]/div/div/img').get_attribute('src')
print(ab)

获取到src之后我们就可以进行下一步操作
在这里插入图片描述

1.使用requests下载文件

下载图片

首先导入requests,把定位找到的图片地址传入dowlimg,写入文件,即可将下载好的文件存入本地

import requests
dowlimg = requests.get(ab)
open('imgtest.jpeg','wb').write(dowlimg.content)
driver.close()

在这里插入图片描述

下载PDF文件

下载PDF文件也是一个道理只要你能够通过selenium定位获取到地址,传入给request就能够把文件给下载下来

import requests
url = 'https://pdf.dfcfw.com/pdf/H2_AN202302051582783380_1.pdf?1675614279000.pdf'
dowlimg = requests.get(url)
open('PDF.pdf','wb').write(dowlimg.content)

2.使用wget下载文件

下载图片

使用wget下载有个麻烦点就是有些网站设置了反爬虫时会出现403拒绝的情况,尝试用了用户代理那些都失败,只能用于下载没有反爬虫的网站图片

import wget
url = "https://img-blog.csdnimg.cn/f6c50979184e417babde47d8f8fbd58e.png#pic_center"
wget.download(url,'image.jpeg')

在这里插入图片描述

下载PDF文件

import wget
url = "https://pdf.dfcfw.com/pdf/H2_AN202302051582783380_1.pdf?1675614279000.pdf"
wget.download(url,'pdf1.pdf')

在这里插入图片描述

3.使用urllib3下载文件

下载图片

import urllib
url = "https://img-blog.csdnimg.cn/f6c50979184e417babde47d8f8fbd58e.png#pic_center"
urllib.request.urlretrieve(url, 'img1.jpeg')

下载PDF文件

import urllib
url = "https://pdf.dfcfw.com/pdf/H2_AN202302051582783380_1.pdf?1675614279000.pdf"
urllib.request.urlretrieve(url, 'img1.jpeg')

在这里插入图片描述

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

轻烟飘荡

我想吃甜筒

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值