Python爬虫从入门到精通:(16)线程池_Python涛哥

2024-03-21 00:50

本文主要是介绍Python爬虫从入门到精通:(16)线程池_Python涛哥,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

线程池

我们暂时用自己的服务器进行爬取(Flask的基本使用)

Flask的基本使用:

  • 环境安装:

    pip install flask
    
  • 创建一个py源文件

  • 详细代码看 FlaskServer.py

    #!/usr/bin/env python3
    # -*- coding: utf-8 -*-
    from flask import Flask, render_template
    from time import sleep# 实例化一个app
    app = Flask(__name__)# 创建试图函数&路由地址
    @app.route('/bobo')
    def index_1():sleep(2)return render_template('test.html')@app.route('/jay')
    def index_2():sleep(2)return render_template('test.html')@app.route('/tom')
    def index_3():sleep(2)return render_template('test.html')if __name__ == '__main__':# debug=True表示开启调试模式:服务器端代码被修改按下保存键会自动重启服务器app.run(debug=True)
    

    运行后,就可以进去自己的网站了
    在这里插入图片描述


线程池:

所谓多线程,官方解释自行了解。

不过用我们通俗的话打比方就是: 多个人同时切菜。比起轮流切菜时间要短,效率要高!

线程池:打比方就是把这些人,这些工作放到一个厨房里,然后启用开始工作!

我们先来看下爬取刚才的Flask网站的 正常爬取步骤:

import time
import requests
from multiprocessing.dummy import Pool# 把这些网站放进一个列表
urls = ['http://127.0.0.1:5000/bobo','http://127.0.0.1:5000/jay','http://127.0.0.1:5000/tom'
]# 创建一个函数模板进行爬取
def get_request(url):page_text = requests.get(url=url).textreturn len(page_text)# 运行执行代码
if __name__ == '__main__':start = time.time() # 记录开始时间for url in urls:print(get_request(url))print('总耗时:', time.time() - start)

上面就是单线程操作(轮流切菜模式),也叫做同步执行!我们来看下结果:

在这里插入图片描述

很显然,我们看到代码执行的时间是6秒左右,说明平均爬取一个网站的速度要2秒左右。


异步爬取:(多人同时切菜模式)

当爬取的网站越多,数据越大,耗时越长,这不是我们想要的。于是就有了多线程,多进程等

异步实现代码:

if __name__ == '__main__':start = time.time()pool = Pool(3)  # 3 表示开启线程的数量# 难点:pool.map。表示一个函数,依次调用参数,然后返回# 使用get_request作为回调函数,需要基于异步的形式对urls列表中的每一个列表元素进行操作# 保证回调函数必须要有一个参数和返回值result_list = pool.map(get_request, urls)print(result_list)print('总耗时:', time.time() - start)

pool.map不理解的话,可以去看下 Python里的map函数,类似的意思。

在这里插入图片描述

代码执行后,我们发现,总耗时才2秒!是不是提升了效率!

关注 Python涛哥!学习更多Python知识!

这篇关于Python爬虫从入门到精通:(16)线程池_Python涛哥的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/tao5090694/article/details/120554656
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/831280

相关文章

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整