python使用多线程爬取糗百段子

2024-01-28 13:20

本文主要是介绍python使用多线程爬取糗百段子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本次是对上次的糗百爬虫做的修改,使用多线程
import requests
from lxml import etree
import threading
from queue import Queueclass Qiubai:def __init__(self):self.headers = {"sec - fetch - dest": "empty","sec - fetch - mode": "cors","sec - fetch - site": "cross - site","User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.129 Safari/537.36"}self.url_list = Queue()  #url队列self.res = Queue()  #响应队列self.str = Queue()  #数据队列def get_url_list(self):'''url队列'''url = "https://www.qiushibaike.com/text/page/{}/"for i in range(13):self.url_list.put(url.format(i))  #循环,创建url队列def get_html(self):'''发送请求'''while True:url = self.url_list.get()  #从队列取出response = requests.get(url, headers=self.headers)  #发送请求self.res.put(response.content.decode())  #放入队列self.url_list.task_done()  #让队列减一def get_html_data(self):'''提取数据'''while True:html_str = self.res.get()  #取出一个响应#提取数据html = etree.HTML(html_str)content_list = html.xpath('//div[@class="content"]')self.str.put(content_list)  #放入队列self.res.task_done()  #res让队列减一def save_data(self):'''保存'''while True:content_list = self.str.get()  # 从队列取出一个with open("糗事百科搞笑段子.text", "a", encoding="utf-8") as f:for i in content_list:i = i.xpath("./span/text()")  # 列表for j in i:a = j.replace("\n", "")  # 去掉\n符号f.write(a)f.write("\n\n\n")self.str.task_done()  # 队列减一def run(self):'''创建线程并开启'''#一个空列表,将所有线程放入里面,然后用for循环startthread_list = []#创建url队列url = threading.Thread(target=self.get_url_list)thread_list.append(url)#发送请求for i in range(20):send = threading.Thread(target=self.get_html)thread_list.append(send)#提取数据for i in range(10):get_data = threading.Thread(target=self.get_html_data)thread_list.append(get_data)#保存数据for i in range(20):save_data = threading.Thread(target=self.save_data)thread_list.append(save_data)#开始线程print("开始")for i in thread_list:i.daemon = True  #子线程设置为守护线程,主线程结束子线程结束i.start()for j in [self.url_list, self.res, self.str]:j.join()  #让主线程等待子线程结束再结束print("结束")if __name__ =="__main__":qiubai = Qiubai()qiubai.run()
结果截图如下

在这里插入图片描述

  • 在创建线程是遇到了一直死循环的BUG
threading.Thread(target=self.get_html)

看了文档才知道我在target等号后面的函数加了括号,其实是不能加的。

这篇关于python使用多线程爬取糗百段子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653737

相关文章

Python中局部变量和全局变量举例详解

《Python中局部变量和全局变量举例详解》:本文主要介绍如何通过一个简单的Python代码示例来解释命名空间和作用域的概念,它详细说明了内置名称、全局名称、局部名称以及它们之间的查找顺序,文中通... 目录引入例子拆解源码运行结果如下图代码解析 python3命名空间和作用域命名空间命名空间查找顺序命名空

Python如何将大TXT文件分割成4KB小文件

《Python如何将大TXT文件分割成4KB小文件》处理大文本文件是程序员经常遇到的挑战,特别是当我们需要把一个几百MB甚至几个GB的TXT文件分割成小块时,下面我们来聊聊如何用Python自动完成这... 目录为什么需要分割TXT文件基础版:按行分割进阶版:精确控制文件大小完美解决方案:支持UTF-8编码

基于Python打造一个全能文本处理工具

《基于Python打造一个全能文本处理工具》:本文主要介绍一个基于Python+Tkinter开发的全功能本地化文本处理工具,它不仅具备基础的格式转换功能,更集成了中文特色处理等实用功能,有需要的... 目录1. 概述:当文本处理遇上python图形界面2. 功能全景图:六大核心模块解析3.运行效果4. 相

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn