alanchen1115 commited on
Commit
a7d72c9
·
verified ·
1 Parent(s): a145c04

Update main.py

Browse files
Files changed (1) hide show
  1. main.py +6 -38
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)