將 GPT Bot 整合到 Line。並且完全免費支援一般問答、圖片生成、圖片推理、線上圖片搜索、文字生影片、圖片生影片...等功能。
-
自然語言對話
-
圖片生成
-
圖片推理
-
文字生成影片
text2video.mp4
-
圖片生成影片
571128484571906539.mp4
-
每週 星座資訊(即時)
-
YouTube 音樂 頻道的定時推播
-
在線圖片搜尋(即時)
Note
如果你有任何功能請求,請隨時提交 PR 或 ISSUE。
Python FastAPI
:創建 ChatGPT 回應 APIgpt4free
:免費使用 OpenAI APIzhipuai
:免費使用 GPT APILine messaging API channel
:連接 ChatGPT APIGitHub
:代碼存儲庫replit/render/ngrok
:免費部署你自己的 FastAPICronJob
:免費發送定時請求,實現定時推播消息
由於 g4f
依賴於逆向工程來調用 OpenAI 的 API,可能會不穩定。因此,作者建議使用 Zhipu AI 開放平台作為免費 GPT API 的替代方案。
g4f
:使用逆向工程調用 OpenAI APIzhipuai
:Zhipu AI 開放平台提供免費 GPT API。訪問 官方網站 註冊帳戶,無需信用卡或費用。在 個人中心 添加 API 金鑰,如下所示。將此 API 金鑰設置在環境變量中使用此 GPT 選項。
- 獲取 Line Tokens:
- 登錄 Line Developer
- 創建一個 bot:
- 創建一個
Provider
-> 點擊Create
- 創建一個
Channel
-> 選擇Create a Messaging API channel
- 填寫所需的基本信息
- 完成後,進入
Basic Settings
-> 在Channel Secret
下,點擊Issue
生成LINE_CHANNEL_SECRET
(後面會用到)。 - 在
Messaging API
下,點擊Issue
生成Channel access token
(後面會用到)。
- 創建一個
-
Fork GitHub 專案:
- 註冊/登錄 GitHub
- 前往 ChatGPT-Line-Bot
- 點擊
Star
支持開發者 - 點擊
Fork
將所有代碼複製到你的存儲庫
-
選擇部屬方式
🏠 本地免費部署
$env:LINE_CHANNEL_SECRET="..."; $env:LINE_CHANNEL_ACCESS_TOKEN="..."; $env:SERPAPI_API_KEY="..."; $env:GPT_METHOD="..."; $env:GPT_API_KEY="..."; python main.py
GPT_METHOD
:選擇g4f
或zhipuai
GPT_API_KEY
:如果使用zhipuai
方法,提供你的 API 金鑰
使用本地電腦作為服務器來部署 API:
-
下載適合你操作系統的
ngrok
版本 -
將
ngrok.exe
路徑添加到系統的環境變量中 -
執行:
ngrok config add-authtoken <token>
。從你的個人 ngrok dashboard 獲取 token。 -
執行:
ngrok http --url=<YOUR STATIC DOMAIN>.ngrok-free.app 8090
(若失敗請改嘗試ngrok http --hostname=<YOUR STATIC DOMAIN>.ngrok-free.app 8090
)
將
https://<YOUR STATIC DOMAIN>.ngrok-free.app/callback
替換 Line Developer 控制台Messaging API
區域中的 webhook URL。☁️ 雲端免費部署
- 前往 Render 並註冊帳戶
- 點擊 "New Web Service"
- 連接你的 GitHub 存儲庫
- 設置環境變數:
LINE_CHANNEL_SECRET
LINE_CHANNEL_ACCESS_TOKEN
SERPAPI_API_KEY
(可選)GPT_METHOD
GPT_API_KEY
(如果使用 zhipuai)
- 部署完成後,使用提供的 URL 作為 webhook
- 結合 cronjob 觸發定時調用服務,避免服務閒置過久關閉
將雲端服務提供的 URL(例如:
https://your-app.render.com/callback
)設置為 Line Developer 控制台中的 webhook URL。
回到 Line Developer 首頁,點擊 Add Friend Guide
,掃描 QR 碼將 Line Bot 添加為好友。
首頁 -> 選擇你的 bot -> 添加好友工具 -> 創建好友動作條碼(https://manager.line.biz/account//gainfriends)
恭喜!你已創建了你的第一個 Line Bot。試著與它交談——它會回覆你!
- 在一對一對話中,任何消息都會觸發回應。
- 在群組對話中,使用
@chat
前綴與機器人互動,例如,@chat hi~
。
自定義 Bot 個性
隨時修改 LineBot 的 System Instruction
,個別定義屬於你喜歡的風格
- 透過關鍵字
@prompt
修改:@prompt 你是一個個性溫和的AI助理,請用繁體中文回答
初始化 Bot
初始化 Bot 的 System Instruction
,並且初始化歷史對話紀錄
- 透過關鍵字
@init
初始化:@init
星座運勢查詢
當你的消息包含星座資訊請求時,網絡爬蟲將抓取每週星座:
- 個人聊天:
給我天蠍座星座
,我想知道天蠍座星座
, ... - 群組聊天:
@chat 給我天蠍座星座
,@chat 我想知道天蠍座星座
, ...
在線圖片搜尋
當你的消息包含圖片請求時,網絡爬蟲將抓取圖片:
- 個人聊天:
在線找到林翔抽煙的圖片
,給我在線林翔抽煙的圖片
, ... - 群組聊天:
@chat 在線找到林翔抽煙的圖片
,@chat 給我在線林翔抽煙的圖片
, ...
圖片生成
只要你輸入「生成」或「創建」相關的圖片請求,Bot 會自動使用 AI 生成圖片並回傳。
- 例如:
生成一隻貓的圖片
,創建一張風景圖
圖片推理(VLM)
先上傳一張圖片,再詢問與圖片內容相關的問題,Bot 會用 AI 進行推理並回覆。
- 例如:上傳圖片後問
這張圖片裡有什麼?
、幫我分析這個截圖
文字生成影片
只要你輸入「生成」或「創建」相關的影片請求,Bot 會自動使用 AI 生成影片並回傳。
- 例如:
生成一段正在走動的貓的影片
圖片生成影片
只要你輸入圖片後,接著輸入「根據圖片生成」或「根據圖片創建」相關的影片請求,Bot 會自動使用 AI 生成影片並回傳。
- 例如:
根據剛剛上船的圖片生成一段...的影片
,
自動廣播消息 - 每日 YouTube 推薦
- 使用
broadcast
API,Line Bot 可以一次性推送消息給所有用戶。 - 此示例演示了 Line Bot 如何每天早上推送 3 首隨機選擇的 YouTube 歌曲:
-
創建文件
./data/favorite_videos.json
。參考作者的數據集。(數據集是使用
YouTube Data v3 API
抓取喜愛視頻生成的。本指南不涉及 YouTube API 的使用。) -
使用
./ChatGPT_linebot/modules/youtube_recommend.py
隨機選擇 3 首歌曲,由 GPT 格式化。 -
在
./ChatGPT_linebot/urls.py
中添加/recommend
路由:videos = recommend_videos() # 獲取 3 首歌曲 if videos: line_bot_api.broadcast(TextSendMessage(text=videos)) # 廣播給用戶 # 推送消息給已知群組 known_group_ids = [ 'C6d-xxxxxxxxxxxxxxxxxxxxxxxxxxxxx', 'Ccc-xxxxxxxxxxxxxxxxxxxxxxxxxxxxx', 'Cbb-xxxxxxxxxxxxxxxxxxxxxxxxxxxxx', ] for group_id in known_group_ids: line_bot_api.push_message(group_id, TextSendMessage(text=videos))
要獲取群組
group_id
,在控制台中打印:elif event.source.type == 'group' and user_message.startswith('@chat'): group_id = event.source.group_id print(group_id) # 輸出 group_id
-
現在,訪問
/recommend
路由將廣播消息給所有用戶和指定群組。 -
使用 cron-job.org 每天早上 8:00 定時推送:
- 註冊/登錄 cron-job.org
- 點擊右上角的
CREATE CRONJOB
- 標題:
ChatGPT-Line-Bot
,URL:例如,https://ChatGPT-Line-Bot.jimmylin.repl.co/
- 設置為每
5 分鐘
运行 - 點擊
CREATE
-