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
猜你喜欢
- 前言可能很多人会觉得这是一个奇葩的需求,爬虫去好好的爬数据不就行了,解析js干嘛?吃饱了撑的?搜索一下互联网上关于这个问题还真不少,但是大多
- this指向当前作用域的对象,如果找不到,往上一层找,直到window。this 关键字很好用,很灵活,正因为很灵活,所以一不小心你就会掉进
- 1.筛选出目标值所在行 单列筛选# df[列名].isin([目标值])对当前列中存在目标值的行会返回True,不存在的返回Fal
- #!/usr/bin/env python# -*- coding: utf-8 -*-'''''
- 其实SQLServer提供了一个sp_spaceused的系统存储过程可以实现该功能,下面就是调用的SQL: 代码如下:crea
- 关于高性能的分布式内存对象缓存系统Memcached,我们在另一篇文章中有提到过“在windows系统下如何安装memcached的讲解”,
- 导言:本文一步一步手把手教你打造一个极酷的三层分离的标准滑动门导航菜单,从思路、原理、步骤,手段可谓“无所不用其极”,即便你是菜鸟,相信你看
- 2020.2.20 更新日志:本文的初衷是因为安装anaconda的时候你并不知道会包含哪个版本的python,因此我制作了下表如果你使用的
- 什么是 PycharmPycharm 是目前最好用的 Python 编辑器,自带文本高亮、版本管理、数据库连接、断点调试、虚拟环境和包管理的
- 目录一,python介绍二.python的安装程序三、变量python基础部分学习一,python介绍python的创始人为吉多·范罗苏姆(
- 概述在列表复制这个问题,看似简单的复制却有着许多的学问,尤其是对新手来说,理所当然的事情却并不如意,比如列表的赋值、复制、浅拷贝、深拷贝等绕
- 安装pyserialpip install pyserial查看可用的端口# coding:utf-8import serial.tools
- 在面向对象的编程中,很多语言都支持函数重载,能根据函数传递的不同个数、类型的参数来做不同的操作,JS对它却不支持,需要我们额外做些小动作。在
- 模板的继承完美在写html的时候会发现,自己多个html文件中又好多东西是一样的,包括静插件的引入 还有有些简单的css样式都不需要修改,这
- 1、选取最适用的字段属性MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。因此,在创建表
- Python函数函数就是把具有独立功能的代码块封装成一个小模块,可以直接调用,从而提高代码的编写效率以及重用性, 需要注意的是, 函数需要被
- 二维码作为一种信息传递的工具,在当今社会发挥了重要作用。从手机用户登录到手机支付,生活的各个角落都能看到二维码的存在。那你知道二维码是怎么解
- 这个功能现在很多网站,论坛都有,本站也有呵呵!如果您还不知道如何实现这个功能,没关系看看本文吧!我将给你介绍怎么给你的网站加上运行代码框的功
- 一、Background当想将照片序列合成延时摄影视频时,可能会发现照片中缺少一张,或者照片序列是跨时间、并不连续的,如图1所示,但PR中只
- 点乘import torchx = torch.tensor([[3,3],[3,3]])y = x*x #x.dot(x)z = torc