微信接入ChatGPT指南
体验ChatGPT强大的功能,包括语音、图片、接入微信公众号等。
1. 注册GPT账号并获取API
获取API的链接: OpenAI API Keys
2. SSH连接工具Finalshell
下载地址
3. 安装过程
使用Ubuntu 20+ 或 Debian 12系统进行安装:
安装构建Python源:
1 2
| apt update apt install build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-dev libssl-dev libreadline-dev libffi-dev wget
|
下载最新版源代码
1
| curl -O https://www.python.org/ftp/python/3.8.18/Python-3.8.18.tar.xz
|
解压压缩包
1
| tar -xf Python-3.8.18.tar.xz
|
导航到源目录运行脚本
1 2
| cd Python-3.8.18 ./configure --enable-optimizations
|
编译安装
安装ffmpeg
安装git
克隆项目
1 2
| git clone https://github.com/zhayujie/chatgpt-on-wechat cd chatgpt-on-wechat/
|
安装核心依赖
1
| pip3 install -r requirements.txt
|
配置config.json
1
| cp config-template.json config.json
|
配置config.json文件,在/root/Python-3.8.18/chatgpt-on-wechat目录下打开,本文末给出配置说明。
首次运行创建日志文件
后台运行程序输出微信二维码
1
| nohup python3 app.py & tail -f nohup.out
|
如果需要重新修改config.json文件,修改以后必须进入程序目录下,再进行上面一步输出二维码重新登录:
1
| cd Python-3.8.18/chatgpt-on-wechat
|
4、config.json文件内容示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| { "open_ai_api_key": "YOUR API KEY", "model": "gpt-3.5-turbo", "proxy": "", "single_chat_prefix": ["bot", "@bot"], "single_chat_reply_prefix": "[bot] ", "group_chat_prefix": ["@bot"], "group_name_white_list": ["ChatGPT测试群", "ChatGPT测试群2"], "group_chat_in_one_session": ["ChatGPT测试群"], "image_create_prefix": ["画", "看", "找"], "conversation_max_tokens": 1000, "speech_recognition": false, "group_speech_recognition": false, "use_azure_chatgpt": false, "azure_deployment_id": "", "azure_api_version": "", "character_desc": "你是ChatGPT, 一个由OpenAI训练的大型语言模型, 你旨在回答并解决人们的任何问题,并且可以使用多种语言与人交流。", "subscribe_msg": "感谢您的关注!\n这里是ChatGPT,可以自由对话。\n支持语音对话。\n支持图片输出,画字开头的消息将按要求创作图片。\n支持角色扮演和文字冒险等丰富插件。\n输入{trigger_prefix}#help 查看详细指令。", "use_linkai": false, "linkai_api_key": "", "linkai_app_code": "" }
|
5、配置说明:
1.个人聊天
个人聊天中,需要以 “bot”或”@bot” 为开头的内容触发机器人,对应配置项 single_chat_prefix (如果不需要以前缀触发可以填写 “single_chat_prefix”: [“”])
机器人回复的内容会以 “[bot] ” 作为前缀, 以区分真人,对应的配置项为 single_chat_reply_prefix (如果不需要前缀可以填写 “single_chat_reply_prefix”: “”)
2.群组聊天
群组聊天中,群名称需配置在 group_name_white_list 中才能开启群聊自动回复。如果想对所有群聊生效,可以直接填写 “group_name_white_list”: [“ALL_GROUP”]
默认只要被人 @ 就会触发机器人自动回复;另外群聊天中只要检测到以 “@bot” 开头的内容,同样会自动回复(方便自己触发),这对应配置项 group_chat_prefix
可选配置: group_name_keyword_white_list配置项支持模糊匹配群名称,group_chat_keyword配置项则支持模糊匹配群消息内容,用法与上述两个配置项相同。(Contributed by evolay)
group_chat_in_one_session:使群聊共享一个会话上下文,配置 [“ALL_GROUP”] 则作用于所有群聊
3.语音识别
添加 “speech_recognition”: true 将开启语音识别,默认使用openai的whisper模型识别为文字,同时以文字回复,该参数仅支持私聊 (注意由于语音消息无法匹配前缀,一旦开启将对所有语音自动回复,支持语音触发画图);
添加 “group_speech_recognition”: true 将开启群组语音识别,默认使用openai的whisper模型识别为文字,同时以文字回复,参数仅支持群聊 (会匹配group_chat_prefix和group_chat_keyword, 支持语音触发画图);
添加 “voice_reply_voice”: true 将开启语音回复语音(同时作用于私聊和群聊),但是需要配置对应语音合成平台的key,由于itchat协议的限制,只能发送语音mp3文件,若使用wechaty则回复的是微信语音。