Spaces:
Running
Running
Update main.py
Browse files
main.py
CHANGED
@@ -19,9 +19,6 @@ model = genai.GenerativeModel('gemini-2.0-flash',
|
|
19 |
generation_config=generation_config,
|
20 |
system_instruction="你是聖誕老人,請使用招牌笑聲做開頭,然後以爽朗愉悅的口氣回答問題。") # 或是使用 "你是博通古今的萬應機器人!"
|
21 |
|
22 |
-
# 使用 model.start_chat 來初始化對話
|
23 |
-
chat_session = model.start_chat(history=[])
|
24 |
-
|
25 |
# 設定 Line Bot 的 API 金鑰和秘密金鑰
|
26 |
line_bot_api = LineBotApi(os.environ["CHANNEL_ACCESS_TOKEN"])
|
27 |
line_handler = WebhookHandler(os.environ["CHANNEL_SECRET"])
|
@@ -99,6 +96,11 @@ def handle_message(event):
|
|
99 |
# # 取得生成結果
|
100 |
# out = completion.parts[0].text
|
101 |
|
|
|
|
|
|
|
|
|
|
|
102 |
# 取得使用者輸入的文字
|
103 |
user_input = event.message.text
|
104 |
# 發送使用者的輸入到聊天會話並獲得回應
|
@@ -120,38 +122,4 @@ def handle_message(event):
|
|
120 |
|
121 |
if __name__ == "__main__":
|
122 |
# 啟動 FastAPI 應用程式
|
123 |
-
uvicorn.run("main:app", host="0.0.0.0", port=7860, reload=True)
|
124 |
-
|
125 |
-
# 註解說明:
|
126 |
-
# import 導入必要的套件
|
127 |
-
# genai.configure 設定 Google AI API 金鑰
|
128 |
-
# generation_config 設定文字生成參數
|
129 |
-
# model 設定使用的 Gemini 模型
|
130 |
-
# line_bot_api 和 line_handler 設定 Line Bot API 和 webhook 處理器
|
131 |
-
# working_status 設定是否正在與使用者交談
|
132 |
-
# app 建立 FastAPI 應用程式
|
133 |
-
# app.add_middleware 設定 CORS
|
134 |
-
# @app.get("/") 處理根路徑請求
|
135 |
-
# @app.post("/webhook") 處理 Line Webhook 請求
|
136 |
-
# @line_handler.add(MessageEvent, message=TextMessage) 處理文字訊息事件
|
137 |
-
# if __name__ == "__main__": 啟動 FastAPI 應用程式
|
138 |
-
# 程式碼功能說明:
|
139 |
-
# 程式碼首先會導入必要的套件,並設定 Google AI API 金鑰、文字生成參數、Gemini 模型以及 Line Bot API。
|
140 |
-
# 接著會建立 FastAPI 應用程式,並設定 CORS。
|
141 |
-
# 程式碼會定義兩個函數:
|
142 |
-
# root() 處理根路徑請求,返回一個簡單的 JSON 訊息。
|
143 |
-
# webhook() 處理 Line Webhook 請求,將處理 Line 事件的任務加入背景工作,並處理無效的簽章錯誤。
|
144 |
-
# 程式碼還定義一個函數 handle_message() 來處理文字訊息事件,它會檢查事件類型和訊息類型,並根據使用者輸入執行不同的動作:
|
145 |
-
# 如果使用者輸入 "再見",回覆 "Bye!"。
|
146 |
-
# 如果正在與使用者交談,則會使用 Gemini 模型生成文字,並將結果回覆給使用者。
|
147 |
-
# 最後,程式碼會啟動 FastAPI 應用程式,開始監聽 HTTP 請求。
|
148 |
-
# 程式碼運行方式:
|
149 |
-
# 將程式碼存為 main.py 文件。
|
150 |
-
# 在環境變數中設定 GOOGLE_API_KEY、CHANNEL_ACCESS_TOKEN 和 CHANNEL_SECRET。
|
151 |
-
# 執行 uvicorn main:app --host 0.0.0.0 --port 7860 --reload 命令啟動 FastAPI 應用程式。
|
152 |
-
# 使用 Line 帳戶與 Line Bot 進行對話。
|
153 |
-
# 注意:
|
154 |
-
# 程式碼中使用 os.environ["GOOGLE_API_KEY"]、os.environ["CHANNEL_ACCESS_TOKEN"] 和 os.environ["CHANNEL_SECRET"] 來存取環境變數,需要先在環境變數中設定這些值。
|
155 |
-
# 程式碼中使用 uvicorn 執行 FastAPI 應用程式,需要先安裝 uvicorn 套件。
|
156 |
-
# 程式碼中使用 google.generativeai 套件,需要先安裝 google-generativeai 套件。
|
157 |
-
# 程式碼中使用 linebot 套件,需要先安裝 linebot 套件。
|
|
|
19 |
generation_config=generation_config,
|
20 |
system_instruction="你是聖誕老人,請使用招牌笑聲做開頭,然後以爽朗愉悅的口氣回答問題。") # 或是使用 "你是博通古今的萬應機器人!"
|
21 |
|
|
|
|
|
|
|
22 |
# 設定 Line Bot 的 API 金鑰和秘密金鑰
|
23 |
line_bot_api = LineBotApi(os.environ["CHANNEL_ACCESS_TOKEN"])
|
24 |
line_handler = WebhookHandler(os.environ["CHANNEL_SECRET"])
|
|
|
96 |
# # 取得生成結果
|
97 |
# out = completion.parts[0].text
|
98 |
|
99 |
+
#
|
100 |
+
# 使用 model.start_chat 來初始化 user_id 的對話
|
101 |
+
user_id = event.source.user_id
|
102 |
+
chat = chat_sessions.get(user_id) or model.start_chat(history=[])
|
103 |
+
chat_sessions[user_id] = chat
|
104 |
# 取得使用者輸入的文字
|
105 |
user_input = event.message.text
|
106 |
# 發送使用者的輸入到聊天會話並獲得回應
|
|
|
122 |
|
123 |
if __name__ == "__main__":
|
124 |
# 啟動 FastAPI 應用程式
|
125 |
+
uvicorn.run("main:app", host="0.0.0.0", port=7860, reload=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|