赞
踩
教程下载地址: 网赚博客https://www.piaodoo.com/创业项目排行榜前十名https://www.piaodoo.com/
图片信息丰富多彩,许多网站上都有大量精美的图片资源。有时候我们可能需要批量下载这些图片,而手动一个个下载显然效率太低。因此,编写一个简单的网站图片爬取程序可以帮助我们高效地获取所需的图片资源。
如果出现模块报错
进入控制台输入:建议使用国内镜像源
pip install 模块名称 -i https://mirrors.aliyun.com/pypi/simple
我大致罗列了以下几种国内镜像源:
清华大学
https://pypi.tuna.tsinghua.edu.cn/simple
阿里云
https://mirrors.aliyun.com/pypi/simple/
豆瓣
https://pypi.douban.com/simple/
百度云
https://mirror.baidu.com/pypi/simple/
中科大
https://pypi.mirrors.ustc.edu.cn/simple/
华为云
https://mirrors.huaweicloud.com/repository/pypi/simple/
腾讯云
https://mirrors.cloud.tencent.com/pypi/simple/
get_imgurl_list(url, imgurl_list)
函数用来获取指定页面中的图片链接,并将这些链接存储在 imgurl_list
列表中。
requests.get(url=url, headers=headers)
发起请求获取页面内容。etree.HTML(html_str)
将页面内容转换为 etree 对象,方便后续使用 XPath 进行解析。imgurl_list
中。get_down_img(imgurl_list)
函数用来下载图片到本地存储。
imgurl_list
中的图片链接,逐个下载图片并保存到本地文件夹中。在 if __name__ == '__main__':
部分:
page_number = 10
。https://www.moyublog.com/95-2-2-{i}.html
。get_imgurl_list()
函数获取图片链接。get_down_img()
函数下载图片到本地。导入必要的库和模块:
import requests # 用于发送HTTP请求 from lxml import etree # 用于解析HTML页面 import time # 用于控制爬取速度 import os # 用于文件操作
定义函数get_imgurl_list(url, imgurl_list)
用于获取图片链接:
def get_imgurl_list(url, imgurl_list): headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.69 Safari/537.36' } response = requests.get(url=url, headers=headers) html_str = response.text html_data = etree.HTML(html_str) li_list = html_data.xpath("//ul[@class='clearfix']/li") for li in li_list: imgurl = li.xpath(".//a/img/@data-original")[0] imgurl_list.append(imgurl)
imgurl_list
列表中。get_down_img(imgurl_list)
用于下载图片:def get_down_img(imgurl_list): os.mkdir("美女") n = 0 for img_url in imgurl_list: headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.69 Safari/537.36' } img_data = requests.get(url=img_url, headers=headers).content img_path = './美女/' + str(n) + '.jpg' with open(img_path, 'wb') as f: f.write(img_data) n += 1
主程序部分:
if __name__ == '__main__': page_number = 10 # 爬取页数 imgurl_list = [] # 存放图片链接 for i in range(0, page_number + 1): url = f'https://www.moyublog.com/95-2-2-{i}.html' print(url) get_imgurl_list(url, imgurl_list) get_down_img(imgurl_list)
page_number
为10。imgurl_list
。get_imgurl_list()
函数获取图片链接。get_down_img()
函数下载图片到本地"美女"文件夹。应对反爬虫策略:许多网站会采取反爬虫措施,限制单个IP的访问频率或次数。通过使用数据获取服务,可以轮换多IP来模仿多个用户访问,降低被封禁的风险。
保证稳定性:有些数据获取服务可能存在不稳定的情况,包括IP连接速度慢、IP被找到等问题。通过建立数据获取服务,可以预先准备多个可用的IP地址,确保程序在某个IP不可用时可以快速切换到其他可用IP,提高爬虫程序的稳定性。
提高访问速度:IP池中的多个IP地址可以并发使用,实现多线程或异步请求,从而加快数据获取速度。通过在数据获取服务中保持一定数量的可用IP地址,可以实现更快速的数据抓取。
应对封禁风险:有些网站会根据某些特定的IP地址或IP段进行封禁,如果整个IP池中的IP都被封禁,可以及时更新IP池中的IP地址,避免影响爬虫程序的正常运行。
降低被识别的风险:当爬虫程序使用固定的IP地址进行访问时,容易被网站识别出是爬虫行为。
import requests # python基础爬虫库 from lxml import etree # 可以将网页转换为Elements对象 import time # 防止爬取过快可以睡眠一秒 import os def get_imgurl_list(url, imgurl_list): headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.69 Safari/537.36'} # 发送请求 response = requests.get(url=url, headers=headers) # 获取网页源码 html_str = response.text # 将html字符串转换为etree对象方便后面使用xpath进行解析 html_data = etree.HTML(html_str) # 利用xpath取到所有的li标签 li_list = html_data.xpath("//ul[@class='clearfix']/li") # 打印一下li标签个数看是否和一页的电影个数对得上 print(len(li_list)) # 输出20,没有问题 for li in li_list: imgurl = li.xpath(".//a/img/@data-original")[0] print(imgurl) # 写入列表 imgurl_list.append(imgurl) def get_down_img(imgurl_list): os.mkdir("美女") n = 0 for img_url in imgurl_list: headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.69 Safari/537.36'} img_data = requests.get(url=img_url, headers=headers).content # # 拼接图片存放地址和名字 img_path = './美女/' + str(n) + '.jpg' # 将图片写入指定位置 with open(img_path, 'wb') as f: f.write(img_data) # 图片编号递增 n = n + 1
if name == ‘main’:
page_number = 10 # 爬取页数
imgurl_list = [] # 存放图片链接
# 1. 循环构建每页的链接
for i in range(0, page_number + 1):
# 页数拼接
url = f’https://www.moyublog.com/95-2-2-{i}.html’
print(url)
# 2. 获取图片链接
get_imgurl_list(url, imgurl_list)
# 3. 下载图片
get_down_img(imgurl_list)
以上就是使用python爬取4K壁纸保存到本地文件夹的全过程的详细内容,更多关于python爬取壁纸保存到本地的资料请关注网赚博客https://www.piaodoo.com/其它相关文章!
友情连接:
茂名一技http://www.szsyby.net/
茂名一技http://www.enechn.com/
美文集http://www.tpyjn.cn/
手游排行前十名http://www.bjkhrx.com/
蔚来汽车http://www.weilaiqiche.cn/
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。