如何使用多线程高效执行包含大量字典参数的列表函数?
列表内的字典参数多线程执行
拥有包含大量字典参数的列表,需要依次使用多线程执行指定的函数,并自定义线程数。
实现方法:
可以使用threadpoolexecutor线程池来实现此功能。该类可创建指定数量的线程,并根据需要分配和释放线程。
以下是实现代码:
import timefrom concurrent.futures import ThreadPoolExecutorimport threadingmy_list = [ {'ip': '192.168.1.2', 'password': '123456', 'user_name': '654321'}, {'ip': '192.168.1.3', 'password': '123456', 'user_name': '654321'}, {'ip': '192.168.1.4', 'password': '123456', 'user_name': '654321'}, {'ip': '192.168.1.5', 'password': '123456', 'user_name': '654321'}, {'ip': '192.168.1.6', 'password': '123456', 'user_name': '654321'}]def dosome(ip, password, user_name): tname = threading.current_thread().getName() time.sleep(1) print(f'{tname} {ip}')tpe = ThreadPoolExecutor(max_workers=3)for m in my_list: tpe.submit(dosome, **m)
此代码创建一个具有 3 个工作线程的线程池(max_workers=3),并依次将字典参数传递给 dosome 函数。
线程池会自动管理线程的创建和销毁。在所有任务完成之前,线程池仍会处于活动状态。一旦所有任务完成,线程池将关闭,释放所有资源。