python之线程池map()方法传递多参数list
作者:不能知道我是谁 发布时间:2022-06-13 09:00:55
线程池map()方法传递多参数list
之前通过threading.thread()进行了助力接口的多线程并发,但是这个针对并发数量较少的时候比较好用,如果并发数量多,除了线程包协程这种处理方式的情况下,我们还可以采用线程池的方法。
线程池的实现通俗讲就是把所有的任务放在了消息队列里,开启多个线程后执行线程,但线程执行结束后不会中断线程任务,会从消息队列内继续获取线程任务进行线程执行,这样线程池就比多线程操作节省了很多创建线程与关闭线程的步骤,节约大部分资源与时间。
线程池并发需要引入模块
import concurrent.futures
ThreadPoolExecutor 内有两种线程池方法 map()与submit()今天先说map()方法
他的语法为
with concurrent.futures.ThreadPoolExecutor() as pool:
res = pool.map(craw, uid_list)
print(res)
map()
内craw为方法名,这里方法命不带()uid_list
为方法参数,map()方法内需要传递list数据类型
先看一下整体代码
5000用户并发助力
def test_case_09(self):
"""5000用户并发助力"""
# 通过yaml配置文件封装方法 获取uid_list
uid_list = YamlHandler(YamlThePath().number_new).get_uid_list()
# add_ticket获取5000账号登陆状态
with concurrent.futures.ThreadPoolExecutor() as pool:
pool.map(AccountAccess().add_ticket, uid_list)
# 5000账号线程池方法助力用户
with concurrent.futures.ThreadPoolExecutor() as pool:
pool.map(PreheatMethod().help, [(uid, self.A, 1) for uid in uid_list])
# 获取用户被助力次数
response = PreheatMethod().init(self.A)
print(f"当前用户被助力次数 :{response['data']['userInfo']['helpedCount']}次")
再来看一下两个接口的方法更好的感知一下
首先是获取登陆状态add_ticket
def add_ticket(self, uid):
"""
获取单独用户t票
:param uid: 单独用户uid
:return:
"""
self.data['url'] = ApiAddress().get_ticket
self.data['host'] = ApiAddress().host
self.params['uid'] = str(uid)
self.params['type'] = 0
self.data['params'] = json.dumps(self.params)
res = r().post(url=ApiAddress().ticket, data=self.data)
print(f'获取t票结果:{uid}{res}')
return uid
很简单的一个接口请求 入参只有一个uid,但是注意一下这里的uid不是list,他只是一个参数。
那么有的同学就会有疑问,map()内传递的方法参数是一个uid内容的list。
map()方法就是把你需要的参数存在list内,通过遍历的方式去请求你指定的接口。
这时候可能有的人又会问,因为我当时也是这么问自己的,如果一个方法内有多个参数,其中这些参数有的甚至都不是固定的内容怎么办。
咱们看一下另一个请求助力接口的方法
def help(self, agrs):
"""
助力用户
:param agrs: uid:当前用户uid to_uid:助力用户uid count:助力次数
:return:
"""
uid, to_uid, count = agrs
self.attrs['toUid'] = str(to_uid)
self.attrs['count'] = count
response = r().response(uid, self.code, "help", **self.attrs)
logger.info(f'help response uid:{uid} to_uid:{to_uid}\n{response}')
return response
没错,我们通过元组的方式传递到助力接口内,通过元组内的关键字位置分别给指定的元素赋值。
再线程池的代码内,我们通过列表推导式把uid_list内的参数便利到你指定好的元组内,当然这里如果是多个参数,也可以用字典,把字典便利key与value当作变化的参数,因为列表推导式给你返回的是list,所以我们把需要的参数放在元组内,元组放在列表内,这样就可以对多参数的方法使用map()线程池进行并发了。
with concurrent.futures.ThreadPoolExecutor() as pool:
pool.map(PreheatMethod().help, [(uid, self.A, 1) for uid in uid_list])
[(uid, self.A, 1) for uid in uid_list]
列表推导式获取后大概就是下方的list数据内容格式
来源:https://blog.csdn.net/weixin_44861659/article/details/124422294


猜你喜欢
- 文章主要讲术了一些SQL Server新的Bug,帮您认识这些被忽略的SQL Server注入技巧。1.关于Openrowset和Opend
- 项目初始化首先我们创建一个目录,初始化 npm,得到一个package.json文件。mkdir react-clicd react-cli
- 1.学习sql之前回忆一下,什么是变量?变量:能存储数据的值。变量是一块内存空间的表示。数组一连串空间变量是存储数据的容器(通俗讲)2.变量
- 运行截图运行效果:什么?你说你看不清烟花?那我换一种颜色,请点开看。实现过程准备工作使用语言和框架:python、pygame。安装pyga
- 要达到二级名的效果,必须一下条件以及流程:1、必须有一个顶级域名,而且此域名必须做好泛解析并做好指向。2、必须有一台属于你的独立的服务器。泛
- Pandas中Series和DataFrame的两种数据类型中都有nunique()和unique()方法。这两个方法作用很简单,都是求Se
- "神经衰弱"翻牌游戏考察玩家的记忆力,游戏的开头会短时间给你看一小部分牌的图案,当玩家翻开两张相同图案牌的时候,会消除,
- 背景有时候爬虫爬过的url需要进行指纹核对,比如Scrapy就是进行指纹核对,如果是指纹重复则不再爬取。当然在入库的时候我还是需要做一次核对
- 在了解装饰器的之前一定要先了解函数作为参数传递, 什么是函数内嵌,请参考我之前写的博客函数简介因为在python里面,函数也是对象,也可以作
- 在网络上的Pandas教程中,很多都提到了如何使用Pandas将已有的数据(如csv,如hdfs等)直接加载成Pandas数据对象,然后在其
- Math对象Math对象是在高中数学课就学过的内置对象。它知道解决最复杂的数学问题的所有公式,如果给它要处理的数字,即能计算出结果。Math
- 前言最近有个软件专业等级考试,以下简称软考,为了更好的复习备考,我打算抓取www.rkpass.cn网上的软考试题。首先讲述一下我爬取软考试
- 为最终用户提供的功能主要由一个HTML文件和两个ASP文件提供,它们负责接受用户的订阅申请以及退出邮件列表申请。 用户的个人信息在图1所示的
- 地址:https://youzan.github.io/vant/#/zh-CN/intro一.引入Vant组件库1.首先运行 npm in
- 一. vue-amap,一个基于 Vue 2.x 和高德地图的地图组件 https://elemefe.github.io/vue-amap
- 介绍lambdaPython用于支持将函数赋值给变量的一个操作符 默认是返回的,所以不用再加return关键字,不然会报错result =
- 1 np.arange(),类似于range,通过指定开始值,终值和步长来创建表示等差数列的一维数组,注意该函数和range一样结果不包含终
- PyQt5表格控件QTableView简介在通常情况下,一个应用需要和一批数据进行交互,然后以表格的形式输出这些信息,这时就需要用到QTab
- BootStrap模态框简单概述Bootstrap Modals(模态框)是使用定制的 Jquery 插件创建的。它可以用来创建模态窗口丰富
- Python文字转语音(调研&成品函数)由于项目需要, 我需要将文字转换为语音, 那么第一步就要进行调研什么是语音合成技术?语音合成