Spaces:
Sleeping
Sleeping
| # 註解說明: | |
| # import 導入必要的套件 | |
| # genai.configure 設定 Google AI API 金鑰 | |
| # generation_config 設定文字生成參數 | |
| # model 設定使用的 Gemini 模型 | |
| # line_bot_api 和 line_handler 設定 Line Bot API 和 webhook 處理器 | |
| # working_status 設定是否正在與使用者交談 | |
| # app 建立 FastAPI 應用程式 | |
| # app.add_middleware 設定 CORS | |
| # @app.get("/") 處理根路徑請求 | |
| # @app.post("/webhook") 處理 Line Webhook 請求 | |
| # @line_handler.add(MessageEvent, message=TextMessage) 處理文字訊息事件 | |
| # if __name__ == "__main__": 啟動 FastAPI 應用程式 | |
| # 程式碼功能說明: | |
| # 程式碼首先會導入必要的套件,並設定 Google AI API 金鑰、文字生成參數、Gemini 模型以及 Line Bot API。 | |
| # 接著會建立 FastAPI 應用程式,並設定 CORS。 | |
| # 程式碼會定義兩個函數: | |
| # root() 處理根路徑請求,返回一個簡單的 JSON 訊息。 | |
| # webhook() 處理 Line Webhook 請求,將處理 Line 事件的任務加入背景工作,並處理無效的簽章錯誤。 | |
| # 程式碼還定義一個函數 handle_message() 來處理文字訊息事件,它會檢查事件類型和訊息類型,並根據使用者輸入執行不同的動作: | |
| # 如果使用者輸入 "再見",回覆 "Bye!"。 | |
| # 如果正在與使用者交談,則會使用 Gemini 模型生成文字,並將結果回覆給使用者。 | |
| # 最後,程式碼會啟動 FastAPI 應用程式,開始監聽 HTTP 請求。 | |
| # 程式碼運行方式: | |
| # 將程式碼存為 main.py 文件。 | |
| # 在環境變數中設定 GOOGLE_API_KEY、CHANNEL_ACCESS_TOKEN 和 CHANNEL_SECRET。 | |
| # 執行 uvicorn main:app --host 0.0.0.0 --port 7860 --reload 命令啟動 FastAPI 應用程式。 | |
| # 使用 Line 帳戶與 Line Bot 進行對話。 | |
| # 注意: | |
| # 程式碼中使用 os.environ["GOOGLE_API_KEY"]、os.environ["CHANNEL_ACCESS_TOKEN"] 和 os.environ["CHANNEL_SECRET"] 來存取環境變數,需要先在環境變數中設定這些值。 | |
| # 程式碼中使用 uvicorn 執行 FastAPI 應用程式,需要先安裝 uvicorn 套件。 | |
| # 程式碼中使用 google.generativeai 套件,需要先安裝 google-generativeai 套件。 | |
| # 程式碼中使用 linebot 套件,需要先安裝 linebot 套件。 |