本篇教大家如何用Python来实现QQ机器人,如有不足欢迎在评论方指出!
简单介绍
安装方法
可在 Python个版本下使用,用 pip 安装:
pip install qqbot
使用方法
一、启动 QQBot
二、操作 QQBot
QQBot 启动后,在另一个控制台窗口使用 qq 命令来操作 QQBot ,目前提供以下命令:
list 命令提供强大的联系人查询功能,例如:
如:
qq list group 机器人测试
例如:
实现我们自己的 QQ 机器人
要实现咱们自己的QQ 机器人超级简单,我们只要注册一个自己的消息响应函数。代码示范:
假如按插件的形式加载 sample.py ,那么这个文件的内容可以简化成:
QQBot 对象的接口
(1) bot.List(tinfo, [cinfo]) --> [contact0, contact1, ..., ]/[]/None
示例:
List 接口的***个参数 tinfo 也可以是一个 ctype 等于 'group'/'discuss' 的 QContact 对象,此时,返回的是该 群/讨论组 的成员列表,如以下第二句和第三句分别返回 群“456班” 的成员列表和该群中名片为 “jack” 的成员列表:
注意第三句不允许是 bot.List(g, card='jack') 的格式。
List 接口的内部执行顺序:
List 接口返回值的含义:
2、 bot.SendTo(contact, content) --> '向 xx 发消息成功'/'错误:...'
(3) bot.GroupXXX(group, membs[, arg]) --> ['成功:...', '成功:...', '错误:...']
(1) bot.List(tinfo, [cinfo]) --> [contact0, contact1, ..., ]/[]/None
示例:
注意上面第三句不允许是 bot.List(g, card='jack') 的格式。
List 接口的内部执行顺序:
List 接口返回值的含义:
(2) bot.SendTo(contact, content) --> '向 xx 发消息成功'/'错误:...'
(3) bot.GroupXXX(group, membs[, arg]) --> ['成功:...', '成功:...', '错误:...']
注册回调函数、被他人 @ 的通知、定制定时任务
注册回调函数
定制定时任务
从 2.1.13 起, qqbot 中提供一个功能强大的函数装饰器 -- QQBotSched 来定制定时任务,示例代码:
二维码管理器、QQBot 配置及命令行参数
二维码的显示模式
配置文件的使用方法
邮箱模式的配置( mailAccount 和 mailAuthCode )
服务器模式的配置( httpServerIP 和 httpServerPort )
自动登录的 QQ 号码( qq )
掉线后自动重启( restartOnOffline )
联系人列表更新的间歇时间( fetchInterval )
联系人列表获取完成后再启动( startAfterFetch )
QQBot-term 服务器端口号( termServerPort )
如:
文本模式显示二维码(cmdQrcode)
调试模式( debug )
若 debug 项设置为 True ,则运行过程中会打印调试信息。
需要被监视的联系人列表( monitorTables )
插件的配置( pluginPath 和 plugins )
命令行参数及配置的优先级
其中:根配置 是固定的,用户无法修改; 默认配置 和 用户配置 可由用户在 v2.1.conf 文件中进行修改;***,还可以在 命令行参数 中输入配置。
smartqq 协议支持及限制
因 smartqq 协议的限制,以下问题无解决办法