botpy 是基于机器人开放平台API 实现的机器人框架,目的提供一个易使用、开发效率高的开发框架。
pip install qq-botpy
更新包的话需要添加 --upgrade
注:需要python3.7+
需要使用的地方import botpy
import botpy
原机器人的老版本qq-bot
仍然可以使用,但新接口的支持上会逐渐暂停,此次升级不会影响线上使用的机器人
通过继承实现bot.Client
, 实现自己的机器人Client
实现机器人相关事件的处理方法,如 on_at_message_create
, 详细的事件监听列表,请参考 事件监听.md
如下,是定义机器人被@的后自动回复:
import botpy
from botpy.types.message import Message
class MyClient(botpy.Client):
async def on_ready(self):
print(f"robot 「{self.robot.name}」 on_ready!")
async def on_at_message_create(self, message: Message):
await message.reply(content=f"机器人{self.robot.name}收到你的@消息了: {message.content}")
注意:每个事件会下发具体的数据对象,如`message`相关事件是`message.Message`的对象 (部分事件透传了后台数据,暂未实现对象缓存)
设置机器人需要监听的事件通道,并启动client
import botpy
from botpy.types.message import Message
class MyClient(botpy.Client):
async def on_at_message_create(self, message: Message):
await self.api.post_message(channel_id=message.channel_id, content="content")
intents = botpy.Intents(public_guild_messages=True)
client = MyClient(intents=intents)
client.run(appid="12345", token="xxxx")
也可以通过预设置的类型,设置需要监听的事件通道
import botpy
intents = botpy.Intents.none()
intents.public_guild_messages=True
如果要使用api
方法,可以参考如下方式:
import botpy
from botpy.types.message import Message
class MyClient(botpy.Client):
async def on_at_message_create(self, message: Message):
await self.api.post_message(channel_id=message.channel_id, content="content")
``examples` <./examples/>`_ 目录下存放示例机器人,具体使用可参考``Readme.md` <./examples/README.md>`_
examples/ . ├── README.md ├── config.example.yaml # 示例配置文件(需要修改为config.yaml) ├── demo_announce.py # 机器人公告API使用示例 ├── demo_api_permission.py # 机器人授权查询API使用示例 ├── demo_at_reply.py # 机器人at被动回复async示例 ├── demo_at_reply_ark.py # 机器人at被动回复ark消息示例 ├── demo_at_reply_embed.py # 机器人at被动回复embed消息示例 ├── demo_at_reply_command.py # 机器人at被动使用Command指令装饰器回复消息示例 ├── demo_at_reply_file_data.py # 机器人at被动回复本地图片消息示例 ├── demo_at_reply_keyboard.py # 机器人at被动回复md带内嵌键盘的示例 ├── demo_at_reply_markdown.py # 机器人at被动回复md消息示例 ├── demo_at_reply_reference.py # 机器人at被动回复消息引用示例 ├── demo_dms_reply.py # 机器人私信被动回复示例 ├── demo_get_reaction_users.py # 机器人获取表情表态成员列表示例 ├── demo_guild_member_event.py # 机器人频道成员变化事件示例 ├── demo_interaction.py # 机器人互动事件示例(未启用) ├── demo_pins_message.py # 机器人消息置顶示例 ├── demo_recall.py # 机器人消息撤回示例 ├── demo_schedule.py # 机器人日程相关示例
更多功能请参考: [https://github.com/tencent-connect/botpy]