QQ机器人制作教程,超详细

完整项目包括框架、代码和详细使用说明可以去链接下载(下载完只需要按照使用说明修改几处地方即可搭建成功!):
QQ机器人基础版(文章1-2所有功能)
QQ机器人多功能版(文章1-3所有功能)

最新功能请看第二篇文章:搭建一个QQ机器人叫女朋友起床!

前期准备

1、机器人框架的下载和配置

(1)首先需要一个qq机器人框架,我使用的是基于mirai 以及 MiraiGo 开发的go-cqhttp(里面有开发文档)。
在这里插入图片描述
框架下载地址
windows推荐下载这个,linux我没试过自己去看文档哈。
在这里插入图片描述

下载后解压得到三个文件。
在这里插入图片描述
(2)双击exe文件,出现如下窗口,一直点击确定就行了(3次):
在这里插入图片描述
然后会生成一个批处理文件,双击它(以后也是直接用它)

在这里插入图片描述
在这里插入图片描述

输入0后回车,然后关闭,此时已经在原来的文件目录下生成了配置文件config.yml。
(3)双击config.yml,输入QQ号和密码(建议使用无登录保护的qq,否则可能出现滑块验证等问题)。
在这里插入图片描述
也可以不输入账号密码,直接运行那个bat文件会出现二维码扫码登录,这样更加安全。

再转到最后两行,把前面的#去掉使其生效(很重要!!很重要!!)
在这里插入图片描述

(4)配置完后直接双击bat文件。等待一段时间出现如下窗口:
在这里插入图片描述
在这里插入图片描述

这两个端口都应该出现(很重要):
在这里插入图片描述
更多问题请看帮助文档
在这里插入图片描述

补充:窗口可能会一直出现如下警告(这个不需要管,是正常现象):
在这里插入图片描述

窗口会一直显示接收到信息,不要关闭

2、python的配置和安装

电脑没有python环境或者觉得配置太麻烦可直接购买exe版本,只要有电脑就可以运行。
QQ机器人基础版exe
QQ机器人多功能版exe
同样里面都有使用说明,配置更加方便

要实现自动回复功能的机器人需要借助一种语言,我选择的是python。
所以需要电脑配置好python环境和安装集成开发环境pycharm。安装教程可以看我的文章—>>>python安装详细教程
当然在实现所有功能之前需要安装一些第三方库,这个不知道的也可以百度。

具体实现

1、发送信息

这包括发送私聊信息和发送群聊信息。下面的函数已经写好了,直接调用函数传入参数就行了。

import socket
def send_msg(resp_dict):
    client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

    ip = '127.0.0.1'
    client.connect((ip, 5700))

    msg_type = resp_dict['msg_type']  # 回复类型(群聊/私聊)
    number = resp_dict['number']  # 回复账号(群号/好友号)
    msg = resp_dict['msg']  # 要回复的消息

    # 将字符中的特殊字符进行url编码
    msg = msg.replace(" ", "%20")
    msg = msg.replace("\n", "%0a")

    if msg_type == 'group':
        payload = "GET /send_group_msg?group_id=" + str(
            number) + "&message=" + msg + " HTTP/1.1\r\nHost:" + ip + ":5700\r\nConnection: close\r\n\r\n"
    elif msg_type == 'private':
        payload = "GET /send_private_msg?user_id=" + str(
            number) + "&message=" + msg + " HTTP/1.1\r\nHost:" + ip + ":5700\r\nConnection: close\r\n\r\n"
    print("发送" + payload)
    client.send(payload.encode("utf-8"))
    client.close()
    return 0

(1)比如发送私聊信息(QQ用接收者的):

resp_dict={'msg_type':'private','number':QQ号,'msg':'你好'}
send_msg(resp_dict)

在这里插入图片描述
(2)发送群聊信息(群号自己用一个):

send_msg({'msg_type': 'group', 'number': QQ群号, 'msg': '大家好'})

(3)当然不止发送文本信息,还可以发表情、图片、音乐等。还可以艾特某人。
例如:发表情

send_msg({'msg_type': 'group', 'number': QQ群号, 'msg': '[CQ:shake]'})

发窗口抖动

send_msg({'msg_type': 'group', 'number': QQ群号, 'msg': '[CQ:shake]'})

还有很多CQcode可以去官方文档查看:http://docs.go-cqhttp.org/cqcode/
在这里插入图片描述

2、获取群成员列表

import requests
def get_group(id):
    response = requests.post('http://127.0.0.1:5700/get_group_member_list?group_id='+str(id)).json()
    for i in response['data']:
        if(i['card']!=''):
            print(i['card']+str(i['user_id']))
        else:
            print(i['nickname']+str(i['user_id']))

直接调用即可(群号随便用一个)

get_group(QQ群号)

会打印出所有群成员的群昵称(未编辑群昵称的打印QQ昵称)和QQ号。

3、接收上报的事件

下面这个代码命名为receive.py,之后方便调用(不要运行这个代码,否则端口会冲突)。这个返回的是事件的上报信息,包括接收到的信息、加好友请求等等。

import socket
import json

ListenSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
ListenSocket.bind(('127.0.0.1', 5701))
ListenSocket.listen(100)

HttpResponseHeader = '''HTTP/1.1 200 OK\r\n
Content-Type: text/html\r\n\r\n
'''

def request_to_json(msg):
    for i in range(len(msg)):
        if msg[i]=="{" and msg[-1]=="\n":
            return json.loads(msg[i:])
    return None

#需要循环执行,返回值为json格式
def rev_msg():# json or None
    Client, Address = ListenSocket.accept()
    Request = Client.recv(1024).decode(encoding='utf-8')
    rev_json=request_to_json(Request)
    Client.sendall((HttpResponseHeader).encode(encoding='utf-8'))
    Client.close()
    return rev_json

4、实现简单的自动回复

需要写一个while循环一直接收返回的rev,然后根据字段里面的信息做出回应。
在这里插入图片描述
下面的代码需要改一处地方,改为你机器人的QQ号。
在这里插入图片描述
可以把下面的代码命名为main.py,之后的代码都是在这里面加的。需要一直运行,不能关闭。


    if rev["post_type"] == "message":
        #print(rev) #需要功能自己DIY
        if rev["message_type"] == "private": #私聊
            if rev['raw_message']=='在吗':
                qq = rev['sender']['user_id']
                send_msg({'msg_type':'private','number':qq,'msg':'我在'})
        elif rev["message_type"] == "group": #群聊
            group = rev['group_id']
            if "[CQ:at,qq=机器人的QQ号]" in rev["raw_message"]:
                if rev['raw_message'].split(' ')[1]=='在吗':
                    qq=rev['sender']['user_id']
                    send_msg({'msg_type':'group','number':group,'msg':'[CQ:poke,qq={}]'.format(qq)})
        else:
            continue
    else:  # rev["post_type"]=="meta_event":
        continue

上述代码实现的是,当私聊对方发送在吗时回复我在;当群聊有人艾特并发送在吗时会戳一戳对方。
请添加图片描述
请添加图片描述
大家也可以去官方文档查看所有的事件和API,实现各种各样的功能。

5、解决重复接收消息的问题(多次回复问题)

接收本地端口的数据时会有重复的报文(大概6次),就像这样:
在这里插入图片描述
解决办法一:
出现这种问题的小伙伴检查一下receive.py,其中的HttpResponseHeader应该和我这样才对。
在这里插入图片描述

解决办法二:(不推荐,比较麻烦)
查看了一下接收到的数据,发现每条信息会被重复接收,于是在while循环里修改对接收数据的处理。
这就需要判断消息的id,如果遇到重复消息id的数据就不做处理。
在这里插入图片描述
(1)在while循环外面增加一个列表
id_list=[]
判断接收数据的message_id是否在列表里,在的话就说明是重复数据,那就不处理。并且由于程序一直在运行,list会不断变大,于是我加了一个判断,如果列表长度大于50就清空。
(2)接收数据的代码替换成以下代码
以前是这样:
在这里插入图片描述
修改之后:

        rev = rev_msg()
        id=rev['message_id']
        if(len(id_list)>=50):
            id_list=[]
        print(id_list)
        #print(time1==time2)
        if id not in id_list:
            id_list.append(id)
            print(rev)
        else:
            continue

这样就不会出现重复接收数据的情况。

第二、三篇文章实现更多功能

实现了更多功能,包括定时发送消息、智能聊天、天气、星座运势、生日书、获取歌词、点歌、爆照等等。
第二文章地址:搭建一个QQ机器人叫女朋友起床!
第三篇文章地址:搭建一个多功能机器人详细教程
首先感谢大家对本文的支持,第二、三篇文章功能更多,跪求大家的支持!!!

请添加图片描述

完整项目下载地址(配置了python环境)

完整项目包括框架、代码和详细使用说明可以去链接下载(下载完只需要按照使用说明修改几处地方即可搭建成功!):
QQ机器人基础版(文章1-2所有功能)
QQ机器人多功能版(文章1-3所有功能)

在这里插入图片描述
使用说明是word版本,说的十分详细,分为以下四个方面:
在这里插入图片描述
在这里插入图片描述

完整项目下载地址(电脑没有python环境)

电脑没有python环境或者觉得配置太麻烦可直接购买exe版本,只要有电脑就可以运行!!
QQ机器人基础版exe
QQ机器人多功能版exe
同样里面都有使用说明,配置更加方便(强烈推荐)!!

在这里插入图片描述
但是这也有一个坏处,就是不可编程修改,功能已经固定了,十分适合新手!!

个人主页(含在线语音对话机器人和一些有趣的功能):皮小孩的个人主页

  • 431
    点赞
  • 2480
    收藏
  • 打赏
    打赏
  • 305
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:技术黑板 设计师:CSDN官方博客 返回首页
评论 305

打赏作者

皮小孩ls

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值