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

保姆级教程:用Python和go-cqhttp给QQ群做个自动回复机器人(附完整代码)

从零构建智能QQ群机器人Python与go-cqhttp实战指南在社群运营中自动回复机器人早已成为提升管理效率的利器。无论是处理高频咨询、新人引导还是定时发布公告一个配置得当的机器人能显著减轻管理员负担。本文将带你深入探索如何基于go-cqhttp框架和Python打造功能丰富的QQ群机器人涵盖从环境搭建到高级功能的完整实现路径。1. 环境准备与基础配置1.1 go-cqhttp的获取与初始化首先需要从官方GitHub仓库下载对应系统版本的go-cqhttp可执行文件。对于Windows用户推荐选择go-cqhttp_windows_amd64.exe版本。下载完成后建议将其放置在独立的项目目录中。首次运行时程序会提示选择通信方式请选择您需要创建的通信方式: 0: HTTP通信 1: 正向WebSocket 2: 反向WebSocket输入0选择HTTP通信后程序会自动生成config.yml配置文件。用文本编辑器打开该文件关键配置项包括account: # 账号相关 uin: 123456789 # QQ账号 password: # 密码为空时使用扫码登录 heartbeat: interval: 0 # 关闭心跳检测 servers: - http: host: 127.0.0.1 port: 5700 post: - url: http://127.0.0.1:5701 # 事件上报地址1.2 Python环境准备确保已安装Python 3.7版本并安装必要的依赖库pip install requests fastapi uvicorn python-dotenv建议使用虚拟环境隔离项目依赖python -m venv venv source venv/bin/activate # Linux/Mac venv\Scripts\activate # Windows2. 核心通信机制实现2.1 HTTP API基础交互go-cqhttp通过HTTP接口提供丰富的功能支持。以下是一个基础的Python封装类import requests from typing import Dict, Any class CQHttpAPI: def __init__(self, api_urlhttp://127.0.0.1:5700): self.api_url api_url def call_api(self, endpoint: str, data: Dict[str, Any]) - Dict: 调用go-cqhttp API url f{self.api_url}/{endpoint} headers {Content-Type: application/json} response requests.post(url, jsondata, headersheaders) return response.json() def send_private_msg(self, user_id: int, message: str) - Dict: 发送私聊消息 data { user_id: user_id, message: message, auto_escape: False # 允许CQ码解析 } return self.call_api(send_private_msg, data) def send_group_msg(self, group_id: int, message: str) - Dict: 发送群消息 data { group_id: group_id, message: message, auto_escape: False } return self.call_api(send_group_msg, data)2.2 消息接收与处理go-cqhttp通过配置的post地址上报事件。我们可以使用FastAPI搭建一个简单的接收服务from fastapi import FastAPI, Request from pydantic import BaseModel app FastAPI() class GroupMessage(BaseModel): message_type: str group_id: int user_id: int message: str raw_message: str app.post(/event) async def handle_event(request: Request): data await request.json() if data.get(post_type) message: if data.get(message_type) group: # 处理群消息 msg GroupMessage(**data) print(f收到群{msg.group_id}消息{msg.message}) # 简单回复逻辑 if 你好 in msg.message: api CQHttpAPI() api.send_group_msg(msg.group_id, f[CQ:at,qq{msg.user_id}] 你好呀) return {status: ok}启动服务命令uvicorn main:app --reload --port 57013. 实用功能实现3.1 新人入群欢迎通过监听群成员增加事件实现欢迎功能class GroupIncrease(BaseModel): post_type: str notice_type: str group_id: int user_id: int app.post(/event) async def handle_event(request: Request): data await request.json() # 新人入群处理 if data.get(notice_type) group_increase: event GroupIncrease(**data) welcome_msg ( f[CQ:at,qq{event.user_id}] 欢迎加入本群\n 请先阅读群公告有问题可以随时管理员~ ) api CQHttpAPI() api.send_group_msg(event.group_id, welcome_msg) # ...其他事件处理3.2 关键词自动回复实现基于关键词的智能回复系统KEYWORD_RESPONSES { 帮助: 本群提供以下帮助\n1. 常见问题解答\n2. 技术支持\n3. 活动咨询, 活动: 最新活动\n- 本周六线上分享会\n- 下月初线下见面会, 规则: 群规则\n1. 禁止广告\n2. 禁止人身攻击\n3. 保持友善交流 } app.post(/event) async def handle_event(request: Request): data await request.json() if data.get(post_type) message and data.get(message_type) group: msg GroupMessage(**data) content msg.message.strip() # 关键词匹配 for keyword, response in KEYWORD_RESPONSES.items(): if keyword in content: api CQHttpAPI() reply f[CQ:at,qq{msg.user_id}] {response} api.send_group_msg(msg.group_id, reply) break3.3 定时任务管理使用APScheduler实现定时公告功能from apscheduler.schedulers.background import BackgroundScheduler from datetime import datetime scheduler BackgroundScheduler() def daily_announcement(): now datetime.now().strftime(%Y-%m-%d %H:%M) message f【每日公告】{now}\n今日话题AI技术交流\n请遵守群规理性讨论 api CQHttpAPI() api.send_group_msg(12345678, message) # 替换为你的群号 # 每天上午10点执行 scheduler.add_job(daily_announcement, cron, hour10) scheduler.start()4. 高级功能与优化4.1 消息持久化与上下文使用SQLite存储消息记录实现上下文感知回复import sqlite3 from contextlib import closing def init_db(): with closing(sqlite3.connect(bot.db)) as conn: cursor conn.cursor() cursor.execute( CREATE TABLE IF NOT EXISTS messages ( id INTEGER PRIMARY KEY AUTOINCREMENT, group_id INTEGER, user_id INTEGER, message TEXT, timestamp DATETIME DEFAULT CURRENT_TIMESTAMP ) ) conn.commit() def save_message(group_id: int, user_id: int, message: str): with closing(sqlite3.connect(bot.db)) as conn: cursor conn.cursor() cursor.execute( INSERT INTO messages (group_id, user_id, message) VALUES (?, ?, ?), (group_id, user_id, message) ) conn.commit()4.2 敏感词过滤实现基础的敏感词检测功能SENSITIVE_WORDS [广告, 赌博, 诈骗] def contains_sensitive(text: str) - bool: return any(word in text for word in SENSITIVE_WORDS) app.post(/event) async def handle_event(request: Request): data await request.json() if data.get(post_type) message and data.get(message_type) group: msg GroupMessage(**data) if contains_sensitive(msg.message): api CQHttpAPI() warning ( f[CQ:at,qq{msg.user_id}] 您的消息包含敏感内容请注意遵守群规\n 多次违规将被移出群聊。 ) api.send_group_msg(msg.group_id, warning)4.3 性能优化建议异步处理使用httpx替代requests进行异步HTTP请求连接池复用HTTP连接减少开销消息队列高负载场景下引入Redis作为消息队列import httpx async def async_send_group_msg(group_id: int, message: str): async with httpx.AsyncClient() as client: data {group_id: group_id, message: message} await client.post(http://127.0.0.1:5700/send_group_msg, jsondata)5. 部署与维护5.1 生产环境部署推荐使用supervisor管理进程[program:go-cqhttp] command/path/to/go-cqhttp directory/path/to/working/dir autostarttrue autorestarttrue [program:bot] commanduvicorn main:app --host 0.0.0.0 --port 5701 directory/path/to/bot autostarttrue autorestarttrue5.2 日志管理配置go-cqhttp的日志输出# config.yml log: level: info format: json output: file path: logs/go-cqhttp.logPython端使用logging模块import logging from logging.handlers import RotatingFileHandler logger logging.getLogger(qqbot) logger.setLevel(logging.INFO) handler RotatingFileHandler( logs/bot.log, maxBytes5*1024*1024, backupCount3 ) formatter logging.Formatter( %(asctime)s - %(name)s - %(levelname)s - %(message)s ) handler.setFormatter(formatter) logger.addHandler(handler)5.3 安全建议使用环境变量存储敏感信息限制API访问IP定期更新go-cqhttp版本from dotenv import load_dotenv import os load_dotenv() API_URL os.getenv(CQHTTP_API_URL, http://127.0.0.1:5700)

相关文章:

保姆级教程:用Python和go-cqhttp给QQ群做个自动回复机器人(附完整代码)

从零构建智能QQ群机器人:Python与go-cqhttp实战指南 在社群运营中,自动回复机器人早已成为提升管理效率的利器。无论是处理高频咨询、新人引导,还是定时发布公告,一个配置得当的机器人能显著减轻管理员负担。本文将带你深入探索如…...

别再只盯着JWT了!手把手教你用Python解密JWE Token(附完整代码)

深入实战:用Python解密JWE Token的全流程指南 在当今的Web应用开发中,Token已成为身份验证和授权的主流方式。大多数开发者对JWT(JSON Web Token)已经相当熟悉,能够轻松地在jwt.io等工具上解码和验证。然而&#xff0c…...

n8n工作流模板库:开箱即用的自动化解决方案与实战指南

1. 项目概述:一个为n8n设计的全功能工作流模板库如果你正在使用或者考虑使用n8n这个强大的工作流自动化工具,那么你很可能已经遇到了一个经典难题:从零开始构建一个复杂的工作流,既耗时又容易出错。你需要考虑节点如何连接、数据如…...

嵌入式信号处理实战:从MCU选型到算法优化的完整指南

1. 项目概述:为什么要在嵌入式平台上搞信号处理?如果你是一名嵌入式工程师,或者正在学习嵌入式开发,听到“信号处理”这个词,第一反应可能是“这不是DSP工程师或者算法工程师的活儿吗?”。确实,…...

OpenClaw开源安全平台:模块化架构、插件化设计与企业级自动化安全运营实践

1. 项目概述:从开源安全工具到企业级安全基线的构建最近在梳理内部安全工具链时,又仔细研究了一下AtlasPA/openclaw-security这个项目。这不仅仅是一个简单的漏洞扫描器或者安全脚本集合,它更像是一个试图将安全左移理念、自动化响应和资产安…...

从SRResNet到实战:基于Pytorch的图像超分辨率重建全流程解析

1. 图像超分辨率重建基础入门 第一次接触图像超分辨率技术时,我被它的魔法般的效果震撼到了。简单来说,这项技术就是让模糊的老照片变清晰,让低分辨率的监控画面呈现更多细节。在实际项目中,我经常遇到客户拿着十几年前的老照片希…...

别再为LocalDateTime头疼了!SpringBoot 3.x全局配置Jackson与表单提交的完整避坑指南

SpringBoot 3.x日期处理终极指南:从Jackson到表单提交的全链路解决方案 每次看到控制台抛出Failed to convert from type [java.lang.String] to type [java.time.LocalDateTime]异常时,我都想对着屏幕大喊:"我知道日期格式应该是yyyy-M…...

跨境电商团队如何用Taotoken调用AI模型批量生成多语言商品描述

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 跨境电商团队如何用Taotoken调用AI模型批量生成多语言商品描述 对于跨境电商运营团队而言,为海量商品生成不同语言版本…...

从零开始:手把手教你用Nachos模拟硬盘,理解文件系统底层布局(附DISK文件分析)

从零开始:手把手教你用Nachos模拟硬盘,理解文件系统底层布局(附DISK文件分析) 操作系统课程中,文件系统往往是最抽象难懂的部分之一。当教授在黑板上画出inode、位图和目录项的关系图时,你是否曾困惑这些逻…...

[特殊字符] MarkText使用指南

📝 MarkText使用指南 【免费下载链接】marktext 📝A simple and elegant markdown editor, available for Linux, macOS and Windows. 项目地址: https://gitcode.com/gh_mirrors/ma/marktext ⚡ 快速入门教程 ❤️ 高级功能详解 ### 在列表中使…...

保姆级教程:用TensorRT 8.5和Python实现ArcFace动态Batch推理(附完整代码)

从零实现ArcFace动态Batch推理:TensorRT 8.5实战手册 人脸识别技术在实际业务场景中往往需要处理海量并发请求,而传统单张图片推理模式难以满足实时性要求。本文将手把手带您完成PyTorch训练的ArcFace模型到TensorRT动态Batch推理的完整部署流程&#xf…...

AI开发者必备:开源资源导航站ai-hub的设计哲学与高效使用指南

1. 项目概述:一个面向AI开发者的开源资源集散地最近在GitHub上闲逛,发现了一个挺有意思的仓库,叫xielong/ai-hub。光看名字,你可能会觉得这又是一个“AI工具箱”或者“模型集合”,但点进去仔细研究后,我发现…...

Windows热键侦探:3分钟快速找出占用快捷键的程序

Windows热键侦探:3分钟快速找出占用快捷键的程序 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否曾经遇到…...

Taotoken用量看板如何让我们清晰掌握各模型消耗与团队使用习惯

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Taotoken用量看板如何让我们清晰掌握各模型消耗与团队使用习惯 作为团队管理者,在引入大模型能力支持业务开发时&#…...

在Matlab中绘制圆锥三维曲面图

这篇博文按参考书绘制圆锥三维曲面图,是在“在Matlab中绘制圆锥三维曲面图”的基础上,调整Z的表达式得到的。已知:z(x^2y^2)^(1/2)。要求:绘制[-20,20]区间的曲面图。在matlab命令行窗口输入以下程序:x-20:…...

Halcon实战:高效遍历指定文件夹图像文件的两种核心方案

1. 工业视觉项目中的图像读取痛点 在工业视觉检测项目中,我们经常需要处理大量存储在本地文件夹中的图像文件。这些文件可能来自产线相机拍摄的产品照片、X光检测图像或是其他光学设备生成的图片。实际项目中,图像文件的命名往往不规范,格式…...

应对开放式目标检测精度与速度瓶颈:GroundingDINO配置实战选择策略

应对开放式目标检测精度与速度瓶颈:GroundingDINO配置实战选择策略 【免费下载链接】GroundingDINO [ECCV 2024] Official implementation of the paper "Grounding DINO: Marrying DINO with Grounded Pre-Training for Open-Set Object Detection" 项…...

LSTM时间序列预测实战:从数据预处理到模型调优全解析

1. 项目概述:当时间序列遇上LSTM在数据分析与预测的领域里,时间序列预测一直是个既经典又充满挑战的课题。无论是金融市场的股价波动、电商平台的销量起伏,还是工业设备的传感器读数、城市交通的流量变化,这些按时间顺序排列的数据…...

告别依赖地狱:手把手教你用Docker一键部署带GUI的Kettle(避坑libwebkitgtk)

告别依赖地狱:用Docker容器化部署Kettle的终极实践指南 每次在Linux服务器上安装Kettle时,你是否也经历过这样的噩梦?先是提示缺少libwebkitgtk库,然后发现yum仓库里根本没有这个包,接着开始疯狂搜索各种第三方源&…...

开源AI代码助手Codetie:本地部署、模型自选与实战调优指南

1. 项目概述:一个面向开发者的AI代码伴侣最近在GitHub上看到一个挺有意思的项目,叫codetie-ai/codetie。乍一看名字,可能以为是某个新的编程语言或者框架,但深入了解后,发现它的定位非常精准:一个开源的、本…...

[NLP]Huggingface模型与数据集高效下载全攻略:告别网络瓶颈

1. 为什么你需要这篇Huggingface下载指南 作为一名NLP工程师,我太理解那种盯着进度条干着急的感受了。记得上个月我在复现一个对话模型时,光是下载6B参数的模型就花了整整一上午——不是因为模型太大,而是公司网络时不时抽风,每次…...

如何免费解锁英雄联盟历史回放?ROFL-Player终极解决方案

如何免费解锁英雄联盟历史回放?ROFL-Player终极解决方案 【免费下载链接】ROFL-Player (No longer supported) One stop shop utility for viewing League of Legends replays! 项目地址: https://gitcode.com/gh_mirrors/ro/ROFL-Player 你是否曾因为英雄联…...

程序员转大模型,这8个必备框架,新手也能快速上手

文章目录前言一、为什么2026年必须学大模型开发?二、8个必备框架详细解析2.1 LangChain:AI应用开发的"事实标准"核心优势2026年最新变化适用场景新手快速上手避坑指南2.2 LangGraph:企业级智能体的"骨架"核心优势为什么2…...

AI系统提示词与模型仓库:提升大模型输出质量的关键

1. 项目概述:AI工具的系统提示词与模型仓库最近在折腾各种AI工具时,我越来越深刻地意识到一个核心问题:决定AI输出质量的,往往不是模型本身,而是你给它的“指令”。这个指令,在专业领域里被称为“系统提示词…...

3分钟掌握Illustrator批量替换神器:ReplaceItems.jsx终极效率指南

3分钟掌握Illustrator批量替换神器:ReplaceItems.jsx终极效率指南 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 还在为Illustrator中重复的替换操作烦恼吗&#xff1f…...

Kubernetic:提升Kubernetes管理效率的桌面客户端工具

1. 项目概述:一个为Kubernetes而生的桌面客户端 如果你和我一样,每天的工作都离不开Kubernetes,那你肯定对 kubectl 命令行工具又爱又恨。爱的是它功能强大、无所不能;恨的是它那陡峭的学习曲线和需要时刻记忆的大量命令与参数。…...

云主机/虚拟机迁移后必看:避开dracut紧急模式,搞定grub2和initramfs引导修复

云主机迁移实战指南:彻底解决GRUB2与initramfs引导故障 当一台云主机或虚拟机从原有环境迁移到新平台时,最令人头疼的莫过于启动时突然陷入dracut紧急模式的黑色深渊。屏幕上一行行红色错误提示仿佛在嘲笑你的无能为力——这场景对于经历过跨云平台迁移…...

工业 DC-DC 性能深度对比解析|钡特电源 DF1-05D15LS 与 E0515S-1WR3 封装互通

在工业控制、仪器仪表、低功耗传感设备等场景中,1W 级隔离工业 DC-DC 模块因体积小、功率密度高、适配性强,成为硬件研发工程师常用的直流电源模块核心器件。随着国产化进程加速,国产工业 DC-DC 模块在性能、稳定性、性价比上逐步实现突破&am…...

怎样免费去掉图片水印?2026年免费去水印工具推荐|在线vs软件对比

在日常工作和生活中,我们经常会遇到带有水印的图片。无论是来自社交媒体平台、在线图库还是其他来源,这些水印往往影响图片的使用效果。2026年,市面上出现了多种免费去水印工具,它们采用不同的技术方案,适用于不同的使…...

MPU6050中断驱动数据采集与采样率优化实战

1. MPU6050中断机制与嵌入式开发实战 刚接触MPU6050时,我最头疼的就是数据采集的实时性问题。用轮询方式读取传感器数据不仅占用CPU资源,还经常错过关键的运动状态变化。后来发现中断机制才是解决问题的钥匙,就像有个贴心助手会在数据准备好…...