python--threading 多线程的简单应用

最近做一个基于itchat的微信机器人,涉及到了点多线程运行的事项。
基于itchat库进行的机器人具有信息监听功能,代码如下。

@itchat.msg_register([TEXT],isFriendChat=True)
def message_reply(msg):
    try:
        FromUserName = msg['FromUserName']
    except:
        print('获取FromUserName失败')

    # admins_username为管理员账号的一个list
    if FromUserName in admins_username:
        if msg['Text'] == '更新数据':
            cont0 = '开始更新数据'
            print(cont0)
            itchat.send_msg(msg=cont0, toUserName=FromUserName)
            # 新建线程用来单独运行更新程序
            update_threading = threading.Thread(target=updatedata,args=('2',))
            update_threading.start()

        else:
            message = "小助手运行正常,可以接收到信息,请发送指令:'更新选品库' or '启动发送' "
            itchat.send_msg(msg=message, toUserName=FromUserName)

itchat.auto_login(hotReload=True)
itchat.run()

itchat 通过itchat.run()会开启监听程序运行,这个时候如果直接在reply里面运行一段长时间的程序,他会暂停掉监听的功能,为了保证互相不影响,所以需要引入多线程。
方法就是

import threading
update_threading = threading.Thread(target=updatedata,args=('2',))
update_threading.start()

这里参数target = updatedata是名为updatedata的function,而args是加入的参数。然后使用start()他就可以单独运行了。再通过微信命令调用运行其他进程的时候都可以这样做,解决线程占用的问题。

下面放一段相关的资料

python–threading多线程总结

threading用于提供线程相关的操作,线程是应用程序中工作的最小单元。python当前版本的多线程库没有实现优先级、线程组,线程也不能被停止、暂停、恢复、中断。

threading模块提供的类:
  Thread, Lock, Rlock, Condition, [Bounded]Semaphore, Event, Timer, local。

threading 模块提供的常用方法
  threading.currentThread(): 返回当前的线程变量。
  threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
  threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。

threading 模块提供的常量:

  threading.TIMEOUT_MAX 设置threading全局超时时间。

Thread类

Thread是线程类,有两种使用方法,直接传入要运行的方法或从Thread继承并覆盖run():

创建线程的两种方法

构造方法:
Thread(group=None, target=None, name=None, args=(), kwargs={})

  group: 线程组,目前还没有实现,库引用中提示必须是None;
  target: 要执行的方法;
  name: 线程名;
  args/kwargs: 要传入方法的参数。

实例方法:
  isAlive(): 返回线程是否在运行。正在运行指启动后、终止前。
  get/setName(name): 获取/设置线程名。

  start(): 线程准备就绪,等待CPU调度
  is/setDaemon(bool): 获取/设置是后台线程(默认前台线程(False))。(在start之前设置)

    如果是后台线程,主线程执行过程中,后台线程也在进行,主线程执行完毕后,后台线程不论成功与否,主线程和后台线程均停止
  如果是前台线程,主线程执行过程中,前台线程也在进行,主线程执行完毕后,等待前台线程也执行完成后,程序停止
  start(): 启动线程。
  join([timeout]): 阻塞当前上下文环境的线程,直到调用此方法的线程终止或到达指定的timeout(可选参数)。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值