import os.path import random import time from multiprocessing import Pool import requests from lxml import etree headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36' } def get_img_src(page): ''' 抓取页面的图片的src :return: ''' for i in range(1, page+1): url = f'https://www.pkdoutu.com/photo/list/?page={i}' print(f'抓取{url}页数据') res = requests.get(url, headers=headers) res.encoding = res.apparent_encoding tree = etree.HTML(res.text) # 抓取图片 img_list = tree.xpath('//img[@referrerpolicy="no-referrer"]/@data-original') yield img_list def download_img(url): ''' 下载图片 :return: ''' time.sleep(random.uniform(0, 1)) img_res = requests.get(url, headers=headers) img_name = url.split('_')[-1] # 通过图片url进行拆分,拿到图片名称和后缀 path = 'img' # 判断路径是否存在,不存在则创建 if not os.path.exists(path): os.mkdir(path) # 写入到文件中 with open(os.path.join(path, img_name), 'wb') as f: f.write(img_res.content) if __name__ == '__main__': pool = Pool() # 通过生成器get_img_src返回图片列表 for url_list in get_img_src(2): for url in url_list: # 循环加入进程池 pool.apply_async(download_img, args=(url, )) pool.close() pool.join() print('over')

时间: 2024-04-25 09:27:17 浏览: 14
这是一个 Python 程序,主要用于从指定网站上抓取图片并下载到本地。程序使用了 multiprocessing 库中的进程池来实现多进程下载,加快了下载速度。其中,get_img_src 函数用于抓取指定页数的图片链接,download_img 函数用于下载指定链接的图片并保存到本地。主函数中使用了进程池来异步下载所有图片。 程序的具体实现步骤如下: 1. 导入所需的库,包括 os.path、random、time、multiprocessing 和 requests。 2. 定义抓取图片链接的函数 get_img_src,通过循环抓取指定页数的页面,并使用 lxml 库解析页面内容,抓取图片链接并返回。 3. 定义下载图片的函数 download_img,通过 requests 库下载指定链接的图片,并将图片保存到本地。 4. 在主函数中使用进程池来异步下载所有图片,具体实现如下: a. 创建进程池 pool。 b. 通过生成器 get_img_src 返回图片链接列表,循环遍历每个链接。 c. 将 download_img 函数加入进程池,并传入图片链接作为参数。 d. 关闭进程池,并等待所有进程完成。 e. 打印下载完成提示信息。 该程序适用于需要大量下载图片的场景,可以通过调整进程池的大小和抓取的页数来适应不同的需求。
相关问题

import os.path import random import time from multiprocessing import Pool import requests from lxml import etree headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36' } def get_img_src(page): ''' 抓取页面的图片的src :return: ''' for i in range(1, page+1): url = f'https://www.pkdoutu.com/photo/list/?page={i}' print(f'抓取{url}页数据') res = requests.get(url, headers=headers) res.encoding = res.apparent_encoding tree = etree.HTML(res.text) # 抓取图片 img_list = tree.xpath('//img[@referrerpolicy="no-referrer"]/@data-original') yield img_list def download_img(url): ''' 下载图片 :return: ''' time.sleep(random.uniform(0, 1)) img_res = requests.get(url, headers=headers) img_name = url.split('_')[-1] # 通过图片url进行拆分,拿到图片名称和后缀 path = 'img' # 判断路径是否存在,不存在则创建 if not os.path.exists(path): os.mkdir(path) # 写入到文件中 with open(os.path.join(path, img_name), 'wb') as f: f.write(img_res.content) if __name__ == '__main__': pool = Pool() # 通过生成器get_img_src返回图片列表 for url_list in get_img_src(2): for url in url_list: # 循环加入进程池 pool.apply_async(download_img, args=(url, )) pool.close() pool.join() print('over') 这段代码请详细讲解

这段代码实现了一个简单的图片爬虫,能够从一个图片网站上抓取图片并下载到本地。 首先,在代码的开头导入了需要用到的模块,包括`os.path`、`random`、`time`、`multiprocessing`、`requests`和`lxml.etree`。其中,`os.path`模块提供了一些常用的函数来处理文件和目录路径,`random`模块用来生成随机数,`time`模块用来控制爬虫的访问速度,`multiprocessing`模块用来进行进程池并发下载,`requests`模块用来实现网络请求,`lxml.etree`模块用来解析HTML文档。 接着,定义了两个函数`get_img_src`和`download_img`。 `get_img_src`函数用来抓取页面的图片的src。它使用了一个`for`循环来遍历每一页,通过`requests`模块发送HTTP请求获取页面的HTML文档,然后使用`lxml.etree`模块解析HTML文档,抓取所有图片的src。最后,通过`yield`关键字返回图片的src列表。 `download_img`函数用来下载图片。它接收一个图片的URL作为参数,使用`requests`模块发送HTTP请求获取图片的二进制数据,然后使用`os.path`模块判断存储图片的文件夹是否存在,如果不存在就创建文件夹,然后将图片的二进制数据写入到本地文件中。 在主函数中,首先创建了一个进程池`pool`,然后通过调用`get_img_src`函数返回图片的src列表。然后,使用两个`for`循环依次遍历每个图片的URL,将其作为参数传递给`pool.apply_async`方法,将下载图片的任务加入到进程池中。最后,调用`pool.close()`方法关闭进程池,调用`pool.join()`方法等待所有任务完成,最终输出执行结束的提示信息。 需要注意的是,在下载图片时,为了避免对网站服务器造成过大的负担,使用了`time`模块生成了一个随机数来控制爬虫的访问速度。同时,为了提高爬虫的效率,使用了`multiprocessing`模块来进行进程池并发下载,可以同时下载多个图片,提高了下载速度。

解释代码importjson importos importtime frommultiprocessingimportPool,cpu_count fromdatetimeimporttimedelta frompydubimportAudioSegment

这段代码的作用是导入了以下几个Python库: - `json`:用于处理JSON格式的数据。 - `os`:提供了许多与操作系统交互的函数。 - `time`:提供了处理时间的函数。 - `multiprocessing`:提供了多进程编程的支持。 - `Pool` 和 `cpu_count`:用于创建进程池和获取CPU核心数量。 - `timedelta`:用于处理时间差。 - `AudioSegment`:用于处理音频文件的库。

相关推荐

最新推荐

recommend-type

解决python脚本中error: unrecognized arguments: True错误

主要介绍了解决python脚本中error: unrecognized arguments: True错误,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

头歌python本月天数.doc

头歌python本月天数 头歌Python本月天数计算教程 一、引言 在Python编程中,经常需要处理与时间相关的任务,包括日期的计算。其中,一个常见的需求是计算某个月份的天数。由于不同月份的天数可能不同(例如,2月有28天或29天,取决于是否为闰年),因此编写一个能够准确计算本月天数的Python程序是非常有用的。本教程将详细介绍如何使用Python来实现这一目标。 二、Python中的日期和时间处理 在Python中,日期和时间通常使用内置的datetime模块来处理。datetime模块提供了许多类和方法,用于表示和操作日期和时间。其中,datetime.date类用于表示日期,包括年、月和日三个部分。 三、计算本月天数 要计算本月天数,我们可以使用datetime.date类的一些方法和属性。具体步骤如下: 获取当前日期 首先,我们需要获取当前的日期。这可以通过datetime.date.today()方法来实现。该方法返回一个表示当前日期的datetime.date对象。 python from datetime import date tod
recommend-type

h5py-3.0.0-cp39-cp39-manylinux1_x86_64.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

小程序项目源码之投融圈小程序(投资、融资类).zip

小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip小程序项目源码之投融圈小程序(投资、融资类).zip
recommend-type

debugpy-1.4.1-cp37-cp37m-manylinux2014_i686.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用前端写一个树形控件读取指定目录的文件夹结构

抱歉,作为AI语言模型,我无法提供完整的前端代码。但是,我可以给您一些指导和建议: 1. 使用递归函数来读取指定目录下的所有子文件夹和文件。 2. 在HTML中使用ul和li标签来构建树形结构。 3. 使用CSS样式来美化树形控件。 4. 使用JavaScript来实现树形控件的交互功能(如展开/收起节点)。 5. 使用Ajax或fetch等技术来异步加载子节点,以提高性能。 6. 如果需要支持拖拽等交互功能,可以考虑使用第三方插件或库(如jQuery UI)。 希望这些建议对您有所帮助!
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。