python微信群管理开禁言_Python实现微信自动欢迎新人入群(Ⅰ )
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实现微信自动欢迎新人入群(Ⅰ )相关推荐
- python微信群管理开禁言_怎么设置群管理员-微信群最需要的,是禁言功能
微信是人们沟通的重要方式.几乎每个人都加了很多微信群,有亲友群.同学群.同事群.兴趣群.小区群等.每个微信群里少则几十人,多则四五百人.每个群里都会有很多人发信息,有时候还是语音和视频的信息,所以,无 ...
- android q微信打不开,微信打不开怎么回事?微信打不开怎么办?
微信打不开怎么回事?微信打不开怎么办? 有的用户把自己手机的微信升级版本之后再打开就会强制退出,闪一下就没了,那么微信打不开怎么回事?其实这种情况大多都是版本不匹配,可以在官网下载适合自己机型或者是手 ...
- 钉钉机器人智能回复_契约机器人开发教程-新人入群智能回复|良心开发工作室...
简介 本教程主要实现: 新人入群: 发送群内欢迎信息 发送私聊新成员 说明: 1.支持契约单Q版和多Q版框架 2.支持内置变量 防止消息内容相同 被屏蔽 3.使用易语言进行开发,需要大家有基础或者需要 ...
- python制作微信个人二维码_Python制作微信机器人,随时陪你聊天
之前给大家分享了怎么用 itchat 库制作微信朋友性别统计图,今天给大家介绍一个更强大的库:wxpy 库. wxpy 在 itchat 的基础上,通过大量接口优化提升了模块的易用性,并进行丰富的功能 ...
- 微信打不开链接怎么办,微信跳转外部浏览器打开
但凡使用微信分享转发链接的朋友,应该都会遇到链接在微信内无法打开的问题,甚至可以说是家常便饭.一般都有以下几种情况: 情况1:分享转发H5网页,但会因为他人举报或微信系统检测到含敏感词和诱导分享内 ...
- python 每天发一次通知_Python开发企业微信机器人每天定时发消息实例
由于办公需要"每天定时推送某消息用来提醒群里面所有人",有同事提议用企业微信自带的机器人来实现此功能.我觉得企业微信的这个工具还不错,具体使用方法我来一一讲述. 企业微信API 企 ...
- python调用微信发送消息过于频繁_python 调用微信 发消息
本篇文章讲述的是调用 python 的 wxpy 包自动发送微信消息. 相当于 登录 微信网页版. 具体代码方便复制,提供一份文字版代码 #!/usr/bin/env python3 # coding ...
- python 在主线程开线程_Python开启线程,在函数中开线程的实例
逻辑处理上分成了多个模块,为了提高效率,前一个模块处理完调用后一个模块操作时使用多线程 我这里遇到的情形是前面取数据后面存到mysql,发现单线程效率很低,改为取数据后开线程存到mysql 开启线程之 ...
- python制作微信个人二维码_Python实现 | 微信带参数的二维码
微信运营越来越多了,这种带参数二维码的使用场景还挺多的,但是网上的实现大都是PHP啥的,还不想写PHP的我只好用Python实现一下了. 关于带参二维码的介绍,记得先看官网:生成带参数的二维码. 先大 ...
最新文章
- 我是如何在天猫、蚂蚁金服、百度等大厂面试中被拒的 | 掘金技术征文
- 中国黑客自揭黑色产业链条:做病毒一定要低调
- C++STL的vector中front(),back(),begin(),end()的用法
- 基于海思开发板的屏幕截图程序(二)
- 前端学习(2475):表单数据绑定处理
- SVG 教程 (六)SVG 阴影,SVG 渐变 - 线性,SVG 渐变- 放射性
- 用Python将音频内容转换为文本格式
- 【DevCloud · 敏捷智库】两种你必须了解的常见敏捷估算方法
- 新闻列表页flex_C端列表页如何设计?
- 以父之名想表达什么_科幻电影《猩球崛起3:终极之战》究竟想表达什么?
- 【笔记 】weex POST请求 body数据服务器获取不到
- DjVu Reader Pro for Mac(djvu阅读器) v2.2.3激活版
- 北斗导航 | 灰常详细的RAIM 基本理论(公式推导)
- xp系统之家官网纯净版系统下载
- 微信api接口调用-触发推送微信群聊列表
- JVM垃圾回收机制(一)
- 微信小程序实现圆形菜单弹出选中动画
- linux如何卸载lightdm,告诉你Ubuntu安装LightDM的方法及命令
- ArcMap模型:批量导出shp
- Tushare学习文档(八 银行间同业拆放利率)