python中threading和queue库实现多线程编程
作者:Cyrus_May 发布时间:2023-01-12 13:59:08
摘要
本文主要介绍了利用python的 threading和queue库实现多线程编程,并封装为一个类,方便读者嵌入自己的业务逻辑。最后以机器学习的一个超参数选择为例进行演示。
多线程实现逻辑封装
实例化该类后,在.object_func函数中加入自己的业务逻辑,再调用.run方法即可。
# -*- coding: utf-8 -*-
# @Time : 2021/2/4 14:36
# @Author : CyrusMay WJ
# @FileName: run.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/Cyrus_May
import queue
import threading
class CyrusThread(object):
def __init__(self,num_thread = 10,logger=None):
"""
:param num_thread: 线程数
:param logger: 日志对象
"""
self.num_thread = num_thread
self.logger = logger
def object_func(self,args_queue,max_q):
while 1:
try:
arg = args_queue.get_nowait()
step = args_queue.qsize()
self.logger.info("progress:{}\{}".format(max_q,step))
except:
self.logger.info("no more arg for args_queue!")
break
"""
此处加入自己的业务逻辑代码
"""
def run(self,args):
args_queue = queue.Queue()
for value in args:
args_queue.put(value)
threads = []
for i in range(self.num_thread):
threads.append(threading.Thread(target=self.object_func,args = args_queue))
for t in threads:
t.start()
for t in threads:
t.join()
模型参数选择实例
# -*- coding: utf-8 -*-
# @Time : 2021/2/4 14:36
# @Author : CyrusMay WJ
# @FileName: run.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/Cyrus_May
import queue
import threading
import numpy as np
from sklearn.datasets import load_boston
from sklearn.svm import SVR
import logging
import sys
class CyrusThread(object):
def __init__(self,num_thread = 10,logger=None):
"""
:param num_thread: 线程数
:param logger: 日志对象
"""
self.num_thread = num_thread
self.logger = logger
def object_func(self,args_queue,max_q):
while 1:
try:
arg = args_queue.get_nowait()
step = args_queue.qsize()
self.logger.info("progress:{}\{}".format(max_q,max_q-step))
except:
self.logger.info("no more arg for args_queue!")
break
# 业务代码
C, epsilon, gamma = arg[0], arg[1], arg[2]
svr_model = SVR(C=C, epsilon=epsilon, gamma=gamma)
x, y = load_boston()["data"], load_boston()["target"]
svr_model.fit(x, y)
self.logger.info("score:{}".format(svr_model.score(x,y)))
def run(self,args):
args_queue = queue.Queue()
max_q = 0
for value in args:
args_queue.put(value)
max_q += 1
threads = []
for i in range(self.num_thread):
threads.append(threading.Thread(target=self.object_func,args = (args_queue,max_q)))
for t in threads:
t.start()
for t in threads:
t.join()
# 创建日志对象
logger = logging.getLogger()
logger.setLevel(logging.INFO)
screen_handler = logging.StreamHandler(sys.stdout)
screen_handler.setLevel(logging.INFO)
formatter = logging.Formatter('%(asctime)s - %(module)s.%(funcName)s:%(lineno)d - %(levelname)s - %(message)s')
screen_handler.setFormatter(formatter)
logger.addHandler(screen_handler)
# 创建需要调整参数的集合
args = []
for C in [i for i in np.arange(0.01,1,0.01)]:
for epsilon in [i for i in np.arange(0.001,1,0.01)] + [i for i in range(1,10,1)]:
for gamma in [i for i in np.arange(0.001,1,0.01)] + [i for i in range(1,10,1)]:
args.append([C,epsilon,gamma])
# 创建多线程工具
threading_tool = CyrusThread(num_thread=20,logger=logger)
threading_tool.run(args)
运行结果
2021-02-04 20:52:22,824 - run.object_func:31 - INFO - progress:1176219\1
2021-02-04 20:52:22,824 - run.object_func:31 - INFO - progress:1176219\2
2021-02-04 20:52:22,826 - run.object_func:31 - INFO - progress:1176219\3
2021-02-04 20:52:22,833 - run.object_func:31 - INFO - progress:1176219\4
2021-02-04 20:52:22,837 - run.object_func:31 - INFO - progress:1176219\5
2021-02-04 20:52:22,838 - run.object_func:31 - INFO - progress:1176219\6
2021-02-04 20:52:22,841 - run.object_func:31 - INFO - progress:1176219\7
2021-02-04 20:52:22,862 - run.object_func:31 - INFO - progress:1176219\8
2021-02-04 20:52:22,873 - run.object_func:31 - INFO - progress:1176219\9
2021-02-04 20:52:22,884 - run.object_func:31 - INFO - progress:1176219\10
2021-02-04 20:52:22,885 - run.object_func:31 - INFO - progress:1176219\11
2021-02-04 20:52:22,897 - run.object_func:31 - INFO - progress:1176219\12
2021-02-04 20:52:22,900 - run.object_func:31 - INFO - progress:1176219\13
2021-02-04 20:52:22,904 - run.object_func:31 - INFO - progress:1176219\14
2021-02-04 20:52:22,912 - run.object_func:31 - INFO - progress:1176219\15
2021-02-04 20:52:22,920 - run.object_func:31 - INFO - progress:1176219\16
2021-02-04 20:52:22,920 - run.object_func:39 - INFO - score:-0.01674283914287855
2021-02-04 20:52:22,929 - run.object_func:31 - INFO - progress:1176219\17
2021-02-04 20:52:22,932 - run.object_func:39 - INFO - score:-0.007992354170952565
2021-02-04 20:52:22,932 - run.object_func:31 - INFO - progress:1176219\18
2021-02-04 20:52:22,945 - run.object_func:31 - INFO - progress:1176219\19
2021-02-04 20:52:22,954 - run.object_func:31 - INFO - progress:1176219\20
2021-02-04 20:52:22,978 - run.object_func:31 - INFO - progress:1176219\21
2021-02-04 20:52:22,984 - run.object_func:39 - INFO - score:-0.018769934807246536
2021-02-04 20:52:22,985 - run.object_func:31 - INFO - progress:1176219\22
来源:https://blog.csdn.net/Cyrus_May/article/details/113663802


猜你喜欢
- Win7安装mysql的具体过程,我的版本是5.5.21 以下是我的安装步骤:1、首先单击MySQL5.5.21的安装文件,出现该数据库的安
- ActiveServerPages,ASP0126(0x80004005)-->找不到包含文件MicrosoftOLEDBProvid
- 这篇文章主要介绍了python return逻辑判断表达式实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价
- Css Reset是什么? 有些同行叫 "css复位",有些可能叫 "默认css".....相信看完
- 前言mysql中有4类运算符,它们是:算术运算符比较运算符逻辑运算符位操作运算符这个大家应该都比较熟悉,但本文给大家总结介绍的关于MySql
- 学习笔记,写到哪是哪。接着上一篇对纯文本文件读写操作,主要去实现一些文件夹操作。创建文件夹创建文件夹的时候往往要先判断文件夹是否存在。样例代
- 引言近期在好几个地方都看到meshgrid的使用,虽然之前也注意到meshgrid的用法。但总觉得印象不深刻,不是太了解meshgrid的应
- window.opener,是通过window.open打开子窗体的父窗体的引用。 比如在父窗体parentForm里面,通过window.
- django接口可以通过localhost或者127.0.0.1进行访问,但无法通过本机ip地址访问1. 修改django项目中的setti
- python数组和列表的区别列表和数组的定义列表用于顺序存储结构。它可以方便、高效的的添加删除元素,并且列表中的元素可以是多种类型。数组是一
- 使用Django框架搭建后端服务器,后台接收前端传递过来xlsx的文件,直接将前端传递的文件转化为DataFrame或直接将文件保存。url
- 在触屏设备上,一些比较基础的手势都需要通过对 touch 事件进行二次封装才能实现。zepto 是移动端上使用率比较高的一个类库,但是其 t
- 当出现直接在pycharm安装一个包很久装不上或者直接失败时,我们选择另一种方式。例如安装pandas包:win+r输入cmd,在cmd中输
- 大家在用asp开发程序的时候,有时候会碰到以下的错误提示:Active Server Pages 错误 'ASP 0141'
- 运用webbrowser库中的一个函数实现自动打开浏览器:webbrowser.open(http://blog.csdn.net/ares
- 目录题目描述:思路:代码:改良版采用递归数学方法题目描述:编写一个算法来确定一个数字是否“快乐”。 快乐的数字按照如下方式确定:从一个正整数
- mysql 之通过配置文件链接数据库配置文件jdbc.properties##MySQLdriver=com.mysql.jdbc.Driv
- MySQL中模式就是数据库SHOW DATABASES;show databases;罗列所有数据库名称CREATE DATABASE &l
- Note: 本解决方案在window10 + anaconda3 +pycharm2020.1.1 + scrapy安装亲测可用问题:安装S
- 前言由于学校科技立项的项目需要实现Android App端与PHP Web端的简单数据交互的实现,当前场景是Web端使用的是MySql数据库