Python实现微信群欢迎机器人

今天暗恋的女孩问我能不能实现wx自动欢迎新人入群。刚开始听到这个要求,本以为会很简单,毕竟Github上有很多开源的项目,完全直接可以克隆一个,根据自己的需求进行一下修改。当时我这么想,也这么做了,结果发Wechat网页版被禁止登录了!!Github上很多开源项目都是基于wechat网页版,通过HTTP进行的交互。然而这是暗恋女孩提出的问题,做不到也得做到。然后经过寻找发现了一个WechatPCAPI,解决了我的问题。

下面进入正题:

首先将WechatPCAPI克隆到我们的目录,如下。

图1.jpg

下面是需要导入的包。

from WechatPCAPI import WechatPCAPI

import time

import logging

from queue import Queue

import threading

首先定义三个队列,用来处理收到的消息:

queue_recved_message = Queue()#用来处理所有消息

queue_groups=Queue() #用来处理群ID消息

queue_Members=Queue()#用来处理群成员信息

然后再定义群成员这个数据结构,群成员有群ID,WXID,昵称三个属性:

class Person:

def __init__(self):

self.chatroom_id = ""

self.wx_id = ""

self.nick_name = ""

接下来定义处理消息队列的函数,要检测新成员进群,首先要获取群ID,然后再更新指定群中成员的变化。如果发现本次更新的群成员信息与上次群成员信息不一致,则多出来的群成员即为新加入的。所以需要获得的消息类型有‘friend::chatroom’,‘member::chatroom’两种。获取这两种消息后,再次分别放到对应的队列中,进行下一步处理。

def thead_handle_mess(wx_inst):

while True:

if not queue_recved_message.empty():

message = queue_recved_message.get()

if 'friend::chatroom' in message.get('type'):

if chatroom in message.get('data',{}).get('chatroom_name',""):

queue_groups.put(message.get('data',{}).get('chatroom_id',""))

elif 'member::chatroom' in message.get('type'):

Per=Person()

Per.chatroom_id=message.get('data',{}).get('chatroom_id',"")

Per.wx_id = message.get('data', {}).get('wx_id', "")

Per.nick_name = message.get('data', {}).get('wx_nickname', "")

queue_Members.put(Per)

接下来在定义更新群成员的函数:

def thead_handle_getmember(wx_inst,Group_list):

while True:

for group in Group_list:

wx_inst.get_member_of_chatroom(group)

time.sleep(20)#间隔多长时间更新一次群成员列表

然后定义获取群列表的函数:

def get_group_list():

Group_list=[]

while queue_groups.empty():

time.sleep(1)

while not queue_groups.empty():

Group_list.append(queue_groups.get())

return Group_list

这里有个问题,那就是一开始程序没有对比的群成员列表,这样它就会向所有的群成员发送欢迎语。为了解决这个问题,我们首先得获取已经存在的群成员列表。

def get_existed_member(wx_inst,Group_list):

member_groups={}

for group in Group_list:

wx_inst.get_member_of_chatroom(group)

while queue_Members.empty():

time.sleep(0.5)

while not queue_Members.empty():

Person=queue_Members.get()

if Person.chatroom_id not in member_groups.keys():

member_group={Person.chatroom_id:[Person]}

member_groups.update(member_group)

elif Person.wx_id not in get_all_id(member_group[Person.chatroom_id]):

member_group[Person.chatroom_id].append(Person)

return member_groups

接下来我们再写欢迎群成员的函数:

def thread_handle_member_welcome(wx_inst,member_groups):

groups=member_groups

with open('config.json', 'r')as f:

j = json.loads(f.read())

mess = j['mess']

while True:

if not queue_Members.empty():

Person=queue_Members.get()

if Person.wx_id not in get_all_id(groups[Person.chatroom_id]):

add_member(Person,groups)

try:

wx_inst.send_text(to_user=Person.chatroom_id,msg=mess, at_someone=Person.wx_id)

except Exception as e:

print(e)

print("Say welcome to {}".format(Person.nick_name))

else:

pass

else:

pass

这是两个杂项的功能,一个是获取所有的群成员wxid,另一个是用来向已有的列表中加入群成员。

def get_all_id(List):

id_list=[]

for i in List:

id_list.append(i.wx_id)

return id_list

def add_member(Person,member_groups):

member_groups[Person.chatroom_id].append(Person)

这样这个小程序的所有组件就写完了,接下来的工作是将它们组合起来:

def main():

print("初始化中...请稍候!")

wx_inst=WechatPCAPI(on_message=onmessage)

wx_inst.start_wechat(block=True)

time.sleep(3)

threading.Thread(target=thead_handle_mess,args=(wx_inst,)).start()

wx_inst.update_frinds()

Group_list=get_group_list()

member_groups=get_existed_member(wx_inst,Group_list)

print("运行中....")

threading.Thread(target=thead_handle_getmember,args=(wx_inst,Group_list,)).start()

threading.Thread(target=thread_handle_member_welcome,args=(wx_inst,member_groups,)).start()

def onmessage(message):

queue_recved_message.put(message)

#这是回调函数

设置下日志记录功能,方便日后排错。

file_name = str(time.strftime("%Y-%m-%d", time.localtime()))+".log"

logging.basicConfig(filename=file_name,level=logging.INFO)

完整代码:

# coding: utf-8

from WechatPCAPI import WechatPCAPI

import time

import logging

from queue import Queue

import threading

file_name = str(time.strftime("%Y-%m-%d", time.localtime()))+".log"

logging.basicConfig(filename=file_name,level=logging.INFO)

queue_recved_message = Queue()#用来处理所有消息

queue_groups=Queue() #用来处理群ID消息

queue_Members=Queue()#用来处理群成员信息

class Person:

def __init__(self):

self.chatroom_id = ""

self.wx_id = ""

self.nick_name = ""

def onmessage(message):

queue_recved_message.put(message)

def thead_handle_mess(wx_inst):

while True:

if not queue_recved_message.empty():

message = queue_recved_message.get()

if 'friend::chatroom' in message.get('type'):

if chatroom in message.get('data',{}).get('chatroom_name',""):

queue_groups.put(message.get('data',{}).get('chatroom_id',""))

elif 'member::chatroom' in message.get('type'):

Per=Person()#生成新的对象

Per.chatroom_id=message.get('data',{}).get('chatroom_id',"")

Per.wx_id = message.get('data', {}).get('wx_id', "")

Per.nick_name = message.get('data', {}).get('wx_nickname', "")

queue_Members.put(Per)

def thead_handle_getmember(wx_inst,Group_list):

while True:

for group in Group_list:

wx_inst.get_member_of_chatroom(group)

time.sleep(60)

def get_group_list():

Group_list=[]

while queue_groups.empty():

time.sleep(1)

while not queue_groups.empty():

Group_list.append(queue_groups.get())

return Group_list

def get_existed_member(wx_inst,Group_list):

member_groups={}

for group in Group_list:

wx_inst.get_member_of_chatroom(group)

while queue_Members.empty():

time.sleep(0.5)

while not queue_Members.empty():

Person=queue_Members.get()

if Person.chatroom_id not in member_groups.keys():

member_group={Person.chatroom_id:[Person]}

member_groups.update(member_group)

elif Person.wx_id not in get_all_id(member_group[Person.chatroom_id]):

member_group[Person.chatroom_id].append(Person)

return member_groups

def thread_handle_member_welcome(wx_inst,member_groups):

groups=member_groups

with open('config.json', 'r')as f:

j = json.loads(f.read())

mess = j['mess']

while True:

if not queue_Members.empty():

Person=queue_Members.get()

if Person.wx_id not in get_all_id(groups[Person.chatroom_id]):

add_member(Person,groups)

try:

wx_inst.send_text(to_user=Person.chatroom_id,msg=mess, at_someone=Person.wx_id)

except Exception as e:

print(e)

print("Say welcome to {}".format(Person.nick_name))

else:

pass

else:

pass

def main():

print("初始化中...请稍候!")

wx_inst=WechatPCAPI(on_message=onmessage)

wx_inst.start_wechat(block=True)

time.sleep(3)

threading.Thread(target=thead_handle_mess,args=(wx_inst,)).start()

wx_inst.update_frinds()

Group_list=get_group_list()

member_groups=get_existed_member(wx_inst,Group_list)

print("运行中....")

threading.Thread(target=thead_handle_getmember,args=(wx_inst,Group_list,)).start()

threading.Thread(target=thread_handle_member_welcome,args=(wx_inst,member_groups,)).start()

def get_all_id(List):

id_list=[]

for i in List:

id_list.append(i.wx_id)

return id_list

def add_member(Person,member_groups):

member_groups[Person.chatroom_id].append(Person)

if __name__ == "__main__":

main()

新人写的不好,将就着看吧,如果有错误,请指出来,谢谢!

python微信群管理开禁言_Python实现微信自动欢迎新人入群(Ⅰ )相关推荐

  1. python微信群管理开禁言_怎么设置群管理员-微信群最需要的,是禁言功能

    微信是人们沟通的重要方式.几乎每个人都加了很多微信群,有亲友群.同学群.同事群.兴趣群.小区群等.每个微信群里少则几十人,多则四五百人.每个群里都会有很多人发信息,有时候还是语音和视频的信息,所以,无 ...

  2. android q微信打不开,微信打不开怎么回事?微信打不开怎么办?

    微信打不开怎么回事?微信打不开怎么办? 有的用户把自己手机的微信升级版本之后再打开就会强制退出,闪一下就没了,那么微信打不开怎么回事?其实这种情况大多都是版本不匹配,可以在官网下载适合自己机型或者是手 ...

  3. 钉钉机器人智能回复_契约机器人开发教程-新人入群智能回复|良心开发工作室...

    简介 本教程主要实现: 新人入群: 发送群内欢迎信息 发送私聊新成员 说明: 1.支持契约单Q版和多Q版框架 2.支持内置变量 防止消息内容相同 被屏蔽 3.使用易语言进行开发,需要大家有基础或者需要 ...

  4. python制作微信个人二维码_Python制作微信机器人,随时陪你聊天

    之前给大家分享了怎么用 itchat 库制作微信朋友性别统计图,今天给大家介绍一个更强大的库:wxpy 库. wxpy 在 itchat 的基础上,通过大量接口优化提升了模块的易用性,并进行丰富的功能 ...

  5. 微信打不开链接怎么办,微信跳转外部浏览器打开

    ​​但凡使用微信分享转发链接的朋友,应该都会遇到链接在微信内无法打开的问题,甚至可以说是家常便饭.一般都有以下几种情况: 情况1:分享转发H5网页,但会因为他人举报或微信系统检测到含敏感词和诱导分享内 ...

  6. python 每天发一次通知_Python开发企业微信机器人每天定时发消息实例

    由于办公需要"每天定时推送某消息用来提醒群里面所有人",有同事提议用企业微信自带的机器人来实现此功能.我觉得企业微信的这个工具还不错,具体使用方法我来一一讲述. 企业微信API 企 ...

  7. python调用微信发送消息过于频繁_python 调用微信 发消息

    本篇文章讲述的是调用 python 的 wxpy 包自动发送微信消息. 相当于 登录 微信网页版. 具体代码方便复制,提供一份文字版代码 #!/usr/bin/env python3 # coding ...

  8. python 在主线程开线程_Python开启线程,在函数中开线程的实例

    逻辑处理上分成了多个模块,为了提高效率,前一个模块处理完调用后一个模块操作时使用多线程 我这里遇到的情形是前面取数据后面存到mysql,发现单线程效率很低,改为取数据后开线程存到mysql 开启线程之 ...

  9. python制作微信个人二维码_Python实现 | 微信带参数的二维码

    微信运营越来越多了,这种带参数二维码的使用场景还挺多的,但是网上的实现大都是PHP啥的,还不想写PHP的我只好用Python实现一下了. 关于带参二维码的介绍,记得先看官网:生成带参数的二维码. 先大 ...

最新文章

  1. 我是如何在天猫、蚂蚁金服、百度等大厂面试中被拒的 | 掘金技术征文
  2. 中国黑客自揭黑色产业链条:做病毒一定要低调
  3. C++STL的vector中front(),back(),begin(),end()的用法
  4. 基于海思开发板的屏幕截图程序(二)
  5. 前端学习(2475):表单数据绑定处理
  6. SVG 教程 (六)SVG 阴影,SVG 渐变 - 线性,SVG 渐变- 放射性
  7. 用Python将音频内容转换为文本格式
  8. 【DevCloud · 敏捷智库】两种你必须了解的常见敏捷估算方法
  9. 新闻列表页flex_C端列表页如何设计?
  10. 以父之名想表达什么_科幻电影《猩球崛起3:终极之战》究竟想表达什么?
  11. 【笔记 】weex POST请求 body数据服务器获取不到
  12. DjVu Reader Pro for Mac(djvu阅读器) v2.2.3激活版
  13. 北斗导航 | 灰常详细的RAIM 基本理论(公式推导)
  14. xp系统之家官网纯净版系统下载
  15. 微信api接口调用-触发推送微信群聊列表
  16. JVM垃圾回收机制(一)
  17. 微信小程序实现圆形菜单弹出选中动画
  18. linux如何卸载lightdm,告诉你Ubuntu安装LightDM的方法及命令
  19. ArcMap模型:批量导出shp
  20. Tushare学习文档(八 银行间同业拆放利率)

热门文章

  1. 【20230221】【剑指1】排序(中等)II
  2. [置顶] Fedora使用入门与基本配置
  3. Cesium缓冲区分析
  4. Pytorch使用--学习记录
  5. 信息技术教研组工作总结
  6. 基于VR技术的输电线路巡检仿真系统
  7. 企业宣传片如何做?上海宣传片公司拍摄与制作看这里
  8. arcmap服务器注册用处,arcgis主要用来干什么(详解arcgis主要功能)
  9. AutoJs学习-查询IP地址的信息
  10. 使用Unity 3D开发Hololens入门教程