当前位置: 首页 > article >正文

(手把手实战指南)利用NoneBot2与QQ官方API,从零构建智能群聊机器人

1. 环境准备与项目初始化想要搭建一个QQ群聊机器人首先需要准备好开发环境。我推荐使用Python 3.8版本这是目前NoneBot2最稳定的支持版本。如果你还没有安装Python可以去官网下载最新版本。安装好Python后我们需要创建一个虚拟环境。这个步骤很重要可以避免不同项目之间的依赖冲突。打开终端Windows用户可以用PowerShell或CMD输入以下命令python -m venv bot_env激活虚拟环境的方法因操作系统而异Windows:.\bot_env\Scripts\activatemacOS/Linux:source bot_env/bin/activate接下来安装NoneBot2框架和QQ适配器pip install nonebot2 nonebot-adapter-qq我建议使用Poetry来管理项目依赖这样能更好地处理版本控制。如果你还没有安装Poetry可以运行pip install poetry然后初始化项目poetry init在项目目录下创建基本的文件结构my_qq_bot/ ├── bot.py # 主程序入口 ├── pyproject.toml # 项目配置文件 └── plugins/ # 插件目录2. 配置QQ机器人应用要使用QQ官方API我们需要先在QQ开放平台申请开发者资格。这个过程可能需要1-2个工作日审核建议提前准备。登录QQ开放平台后按照以下步骤操作创建新应用选择机器人类型填写应用基本信息获取AppID和AppSecret这些信息很重要不要泄露设置机器人回调地址开发阶段可以先使用本地测试地址在项目根目录创建.env文件配置你的QQ机器人凭证QQ_BOT_APP_ID你的AppID QQ_BOT_APP_SECRET你的AppSecret QQ_BOT_TOKEN你的机器人Token3. 编写第一个机器人响应器现在我们来编写最简单的机器人响应代码。在bot.py文件中import nonebot from nonebot.adapters.qq import Adapter as QQAdapter nonebot.init() driver nonebot.get_driver() driver.register_adapter(QQAdapter) nonebot.load_builtin_plugins(echo) # 加载内置echo插件 if __name__ __main__: nonebot.run()这个基础配置会让机器人响应所有它的消息。让我们测试一下是否工作正常python bot.py如果一切顺利你应该能看到NoneBot2的启动日志。现在你可以在QQ群里你的机器人它会回复你发送的内容。4. 实现实用功能插件4.1 天气查询功能让我们实现一个实用的天气查询功能。在plugins目录下创建weather.pyfrom nonebot import on_command from nonebot.adapters.qq import MessageEvent, MessageSegment from nonebot.params import CommandArg import httpx weather on_command(天气, aliases{weather, 查天气}, priority5) weather.handle() async def handle_weather(event: MessageEvent, args: str CommandArg()): location args.extract_plain_text() if not location: await weather.finish(请输入要查询的城市名称例如/天气 北京) try: async with httpx.AsyncClient() as client: response await client.get( fhttps://api.seniverse.com/v3/weather/now.json, params{ key: 你的天气API密钥, location: location, language: zh-Hans, unit: c } ) data response.json() if results not in data: await weather.finish(找不到该城市的天气信息) result data[results][0] weather_info result[now] location_name result[location][name] msg ( f{location_name}当前天气\n f天气状况{weather_info[text]}\n f温度{weather_info[temperature]}℃\n f体感温度{weather_info[feels_like]}℃\n f湿度{weather_info[humidity]}%\n f风向{weather_info[wind_direction]}\n f风力{weather_info[wind_scale]}级 ) await weather.finish(msg) except Exception as e: await weather.finish(f获取天气信息失败{str(e)})4.2 自动回复功能有时候我们需要机器人能自动回复特定关键词。创建一个auto_reply.py插件from nonebot import on_message from nonebot.rule import keyword from nonebot.adapters.qq import MessageEvent greeting on_message(rulekeyword(你好, hi, hello)) greeting.handle() async def handle_greeting(event: MessageEvent): user_id event.get_user_id() await greeting.finish(f你好呀{user_id}我是你的QQ机器人助手~)4.3 图片处理功能机器人还可以处理图片消息。创建一个image_processor.pyfrom nonebot import on_message from nonebot.adapters.qq import MessageEvent, MessageSegment from nonebot.rule import Rule async def is_image_message(event: MessageEvent) - bool: return bool(event.get_message()[image]) image_processor on_message(ruleRule(is_image_message)) image_processor.handle() async def handle_image(event: MessageEvent): images event.get_message()[image] for img in images: await image_processor.send(收到图片正在处理...) # 这里可以添加图片处理逻辑 await image_processor.send(MessageSegment.text(图片处理完成))5. 部署与优化5.1 本地测试与调试在开发过程中可以使用热重载功能方便调试nb run --reload这样修改代码后NoneBot2会自动重新加载无需手动重启。5.2 生产环境部署当机器人功能开发完成后可以考虑部署到服务器上。我推荐使用以下方案使用supervisor管理进程配置Nginx反向代理使用HTTPS确保通信安全创建supervisor配置文件/etc/supervisor/conf.d/qq_bot.conf[program:qq_bot] command/path/to/your/bot_env/bin/python /path/to/your/bot.py directory/path/to/your/project useryour_user autostarttrue autorestarttrue stderr_logfile/var/log/qq_bot.err.log stdout_logfile/var/log/qq_bot.out.log5.3 性能优化建议使用异步HTTP客户端如httpx代替requests对频繁访问的数据添加缓存合理设置消息处理的优先级(priority参数)避免在消息处理函数中执行耗时操作6. 高级功能扩展6.1 数据库集成要让机器人记住用户数据可以集成数据库。以SQLite为例import sqlite3 from nonebot import require require(nonebot_plugin_sqlite) # 初始化数据库 conn sqlite3.connect(bot_data.db) cursor conn.cursor() # 创建用户表 cursor.execute( CREATE TABLE IF NOT EXISTS users ( user_id TEXT PRIMARY KEY, nickname TEXT, join_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ) ) conn.commit()6.2 定时任务NoneBot2支持定时任务功能。例如每天早上的天气播报from nonebot import require from nonebot_plugin_apscheduler import scheduler require(nonebot_plugin_apscheduler) scheduler.scheduled_job(cron, hour8, minute0) async def morning_weather_report(): # 获取天气数据并发送到指定群组 pass6.3 消息持久化记录聊天历史很有用可以创建一个消息日志插件from nonebot import on_message from nonebot.adapters.qq import MessageEvent from datetime import datetime message_logger on_message(priority999) # 设置低优先级确保最后执行 message_logger.handle() async def log_message(event: MessageEvent): with open(message_log.txt, a, encodingutf-8) as f: timestamp datetime.now().strftime(%Y-%m-%d %H:%M:%S) user_id event.get_user_id() content event.get_message().extract_plain_text() f.write(f[{timestamp}] {user_id}: {content}\n)7. 常见问题解决在实际开发中你可能会遇到这些问题消息发送失败检查机器人是否被禁言或者消息内容是否包含敏感词API请求超时增加超时时间或添加重试机制依赖冲突使用虚拟环境并定期更新依赖性能瓶颈对耗时操作使用异步执行避免阻塞主线程调试时可以启用更详细的日志import logging logging.basicConfig( levellogging.DEBUG, format%(asctime)s - %(name)s - %(levelname)s - %(message)s )记得在实际开发中替换示例代码中的API密钥和敏感信息这些配置最好通过环境变量管理。随着你对NoneBot2的熟悉可以尝试开发更复杂的功能比如自然语言处理、机器学习模型集成等。

相关文章:

(手把手实战指南)利用NoneBot2与QQ官方API,从零构建智能群聊机器人

1. 环境准备与项目初始化 想要搭建一个QQ群聊机器人,首先需要准备好开发环境。我推荐使用Python 3.8版本,这是目前NoneBot2最稳定的支持版本。如果你还没有安装Python,可以去官网下载最新版本。 安装好Python后,我们需要创建一个虚…...

从付费软件到自主开发:我用AI和FFmpeg实现了一个录屏工具粱

我为什么会发出这个疑问呢?是因为我研究Web开发中的一个问题时,HTTP请求体在 Filter(过滤器)处被读取了之后,在 Controller(控制层)就读不到值了,使用 RequestBody 的时候。 无论是字…...

Americhem于Chinaplas 2026宣布在华新增投资,进一步拓展其全球医疗健康业务版图

全球领先的高分子材料解决方案提供商Americhem今日宣布,通过在中国苏州新建一座洁净复合材料生产设施,进一步强化其在医疗健康领域的能力;同时,公司还将在Chinaplas 2026展会上推出多项先进材料技术。该设施预计将于2026年下半年投…...

深入S7协议栈:从TPKT、COTP到PDU,手把手用Wireshark抓包分析Java通信全过程

深入S7协议栈:从TPKT、COTP到PDU,手把手用Wireshark抓包分析Java通信全过程 工业自动化领域,西门子S7协议作为PLC通信的事实标准,其底层协议栈的复杂性常常让开发者望而生畏。当基于Java的iot-communication库与西门子PLC通信出现…...

Fan-Out晶圆级封装(FOWLP)的三种工艺对比:面朝上、面朝下、RDL-first,哪种更适合你的芯片?

Fan-Out晶圆级封装(FOWLP)的三种工艺对比:面朝上、面朝下、RDL-first,哪种更适合你的芯片? 在半导体封装领域,Fan-Out晶圆级封装(FOWLP)技术正逐渐成为高性能芯片的首选方案。这种技…...

信托资金流向与交易对手辨析:钱给了谁,谁就是交易对手吗?

目录 一、 核心误区:资金流向 ≠ 交易对手 二、 谁才是真正的“交易对手”? 三、 如何一眼识别真正的交易对手? 总结 在信托业务和资产管理领域,很多初学者甚至从业者容易产生一个误区:认为信托公司把钱打给谁&…...

2026年软件测试十大趋势预测:AI将重塑一切?

站在质效革命的十字路口当软件从静态工具进化为驱动社会运转的智能神经中枢,其复杂性与不确定性呈指数级增长。传统质量保障体系正经历系统性重构,AI的深度渗透、开发范式的升维以及业务对极致体验的追求,共同推动软件测试迈入“质效革命”新…...

LabVIEW开发的TestStand多工位并行测试框架:支持独立测试、序列编辑与参数编辑功能...

labview 编写的类teststand多工位并行测试框架,带单独的测试和序列编辑,参数编辑功能,具体的见图片,功能正常,多工位测试,带源码最近在捣鼓一个用LabVIEW编写的类TestStand多工位并行测试框架,感…...

EoH Platform:嵌入式多协议物联网边缘中间件

1. EoH Platform 概述:面向工业物联网的多协议嵌入式中间件平台 EoH Platform(Edge of Hub Platform)并非传统意义上的单功能驱动库或轻量级协议栈,而是一个专为资源受限嵌入式设备设计的 可裁剪、可扩展、协议无关的物联网边缘中…...

AD22100K温度传感器嵌入式驱动设计与ADC信号链优化

1. OSS-EC_ADI_AD22100K_00000057 温度传感器驱动库深度解析1.1 器件特性与工程定位OSS-EC_ADI_AD22100K_00000057 是面向 Analog Devices AD22100K 集成温度传感器的嵌入式软件驱动库。该库并非通用型传感器框架,而是针对 AD22100K 独特模拟输出特性的专用适配层&a…...

RVC变声器终极教程:10分钟训练高质量AI音色模型完全指南

RVC变声器终极教程&#xff1a;10分钟训练高质量AI音色模型完全指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-Conve…...

BFS入门经典

#include <cstring> #include <iostream> #include <algorithm> #include <queue>using namespace std;// pair<int,int> 用来存一个点的坐标 (x, y) typedef pair<int, int> PII;const int N 110;int n, m; // n 行 m 列 i…...

ClickEncoder库深度解析:嵌入式旋转编码器+按键一体化驱动方案

1. ClickEncoder 库深度解析&#xff1a;面向嵌入式系统的高鲁棒性旋转编码器按键一体化输入方案旋转编码器&#xff08;Rotary Encoder&#xff09;与集成按键&#xff08;Push Button&#xff09;构成的复合人机交互模块&#xff0c;广泛应用于工业控制面板、医疗设备参数调节…...

如何在Linux桌面环境下实现高效屏幕翻译:CuteTranslation完整解决方案深度解析

如何在Linux桌面环境下实现高效屏幕翻译&#xff1a;CuteTranslation完整解决方案深度解析 【免费下载链接】CuteTranslation Linux屏幕取词翻译软件 项目地址: https://gitcode.com/gh_mirrors/cu/CuteTranslation 对于Linux用户来说&#xff0c;面对外文技术文档、学术…...

从Sora2到Veo-3.1:2025年AI视频生成,我们离‘电影级’还有多远?

2025年AI视频生成技术实战测评&#xff1a;Sora2、Veo-3.1与Vidu Q2如何重塑创作流程 当清晨的第一缕阳光透过工作室的玻璃窗&#xff0c;视频创作者小林已经坐在电脑前开始了一天的工作。与三年前不同的是&#xff0c;她的桌面上不再堆满拍摄设备&#xff0c;取而代之的是三块…...

Buildroot外部工具链路径解析:从权限问题到正确配置

1. Buildroot外部工具链路径问题解析 第一次用Buildroot配置外部工具链时&#xff0c;我遇到了一个典型的路径解析问题。当时选择的工具链路径是/opt/cross-toolchain/bin/arm-linux-gnueabihf-gcc&#xff0c;编译过程中却报错提示找不到libgcc_s.so。这种问题看似简单&#x…...

Vue——Vue 面包屑导航实现

背景问题&#xff1a; 需要实现页面面包屑导航。 方案思考&#xff1a; 根据当前路由路径生成面包屑。 具体实现&#xff1a; 面包屑组件&#xff1a; <!-- components/Breadcrumb.vue --> <template><el-breadcrumb class"app-breadcrumb" separa…...

告别重复登录!用Playwright连接你已登录的Chrome,5分钟搞定自动化数据采集

5分钟实现浏览器自动化&#xff1a;Playwright接管已登录Chrome实战指南 每次运行自动化脚本都要重新登录网站&#xff1f;面对短信验证码和复杂风控系统时束手无策&#xff1f;或许你需要的不是更强大的爬虫&#xff0c;而是换个思路——直接接管你已经登录好的Chrome浏览器。…...

5分钟搞定Java语音识别:SmartJavaAI整合Whisper和Vosk的实战教程

Java语音识别极速集成指南&#xff1a;Whisper与Vosk双引擎实战 语音交互正在重塑人机交互的边界。想象一下&#xff0c;你的Java应用能够听懂用户指令、实时转录会议内容&#xff0c;甚至分析语音情感——这一切不再需要复杂的算法团队支持。本文将带你用五分钟突破技术壁垒&a…...

终极RDP Wrapper配置指南:解锁Windows多用户远程桌面全功能

终极RDP Wrapper配置指南&#xff1a;解锁Windows多用户远程桌面全功能 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap 还在为Windows远程桌面的"不支持"状态而烦恼吗&#xff1f;&#x1f914; RDP Wra…...

OpenClaw跨平台部署对比:本地千问3.5-35B-A3B-FP8与星图云端镜像性能测试

OpenClaw跨平台部署对比&#xff1a;本地千问3.5-35B-A3B-FP8与星图云端镜像性能测试 1. 测试背景与实验设计 去年夏天&#xff0c;当我第一次尝试用OpenClaw自动化处理每周的技术周报时&#xff0c;发现同样的任务在不同环境下的表现差异巨大。这促使我系统性地对比了本地部…...

终极视频加速指南:用Video Speed Controller节省50%观看时间

终极视频加速指南&#xff1a;用Video Speed Controller节省50%观看时间 【免费下载链接】videospeed HTML5 video speed controller (for Google Chrome) 项目地址: https://gitcode.com/gh_mirrors/vi/videospeed 想要在更短时间内学习更多知识吗&#xff1f;想要高效…...

【仅限首批200位AI平台工程师】:手把手搭建支持LoRA热切换+Embedding降维的实时告警管道(含开源eBPF探针源码)

第一章&#xff1a;AI原生软件研发监控告警体系搭建 2026奇点智能技术大会(https://ml-summit.org) AI原生软件具备动态推理路径、模型权重热更新、多模态输入响应等特性&#xff0c;传统基于静态服务拓扑的监控体系难以捕获其运行时语义异常。构建面向AI原生应用的监控告警体…...

Git-RSCLIP优化技巧:英文标签这样写,遥感图像分类准确率更高

Git-RSCLIP优化技巧&#xff1a;英文标签这样写&#xff0c;遥感图像分类准确率更高 1. 为什么标签描述如此重要 在遥感图像分类任务中&#xff0c;标签描述的质量直接影响Git-RSCLIP模型的分类准确率。与通用图像分类不同&#xff0c;遥感图像包含大量专业地物特征&#xff…...

别再只盯着相角裕度了!深入理解增益裕度gm对系统鲁棒性的影响

别再只盯着相角裕度了&#xff01;深入理解增益裕度gm对系统鲁棒性的影响 在控制系统的稳定性分析中&#xff0c;相角裕度(Phase Margin)常常是工程师们关注的焦点&#xff0c;而增益裕度(Gain Margin)则容易被忽视。这种偏重可能源于传统教材中简化案例的示范效应——在大多数…...

别再死记硬背VAE公式了!用PyTorch手把手带你理解‘重参数化’这个核心技巧

从代码实践理解VAE重参数化&#xff1a;为什么这个技巧让生成模型真正"可训练" 在深度学习领域&#xff0c;变分自编码器&#xff08;VAE&#xff09;作为生成模型的经典代表&#xff0c;其核心思想是通过学习数据的潜在分布来生成新样本。但许多初学者在理解VAE时&a…...

SITS2026首批通过架构案例全披露(含字节/阿里/平安内部PPT精要),仅剩最后23个企业可申请架构对标评估

第一章&#xff1a;SITS2026深度解析&#xff1a;AI原生应用架构设计 2026奇点智能技术大会(https://ml-summit.org) AI原生应用已不再满足于将模型“封装后调用”&#xff0c;而是要求从基础设施、服务编排、状态管理到用户交互的全栈重构。SITS2026&#xff08;Singularity …...

从按键消抖到数据锁存:手把手用Multisim仿真SR锁存器和D锁存器的经典应用

从按键消抖到数据锁存&#xff1a;手把手用Multisim仿真SR锁存器和D锁存器的经典应用 在数字电路设计中&#xff0c;锁存器作为基础存储单元&#xff0c;其应用场景远比教科书中的理论推导更丰富。本文将带您通过Multisim仿真平台&#xff0c;从实际工程角度重现两个经典案例&a…...

腾讯云服务器域名绑定实战:从IP到域名的无缝切换

1. 为什么需要将IP地址绑定到域名&#xff1f; 想象一下&#xff0c;你刚在腾讯云上买了一台服务器&#xff0c;兴奋地搭建了自己的个人博客。这时候你发现访问网站只能通过一串数字组成的IP地址&#xff0c;比如123.456.789.123。不仅难记&#xff0c;而且显得很不专业。这就是…...

科研效率翻倍:如何用MATLAB脚本批量处理并导入多个三维荧光样本到DOMfluor?

科研效率革命&#xff1a;MATLAB全自动三维荧光数据处理流水线设计 在环境科学、化学分析等领域&#xff0c;三维荧光光谱技术已成为解析复杂有机物组成的利器。但面对每周产生的数十个Aqualog数据文件&#xff0c;研究人员往往陷入重复劳动的泥潭——手动调整数据格式、逐个导…...