Python調(diào)用DeepSeek?API的完整操作指南
簡(jiǎn)介
本文將詳細(xì)介紹如何使用 Python 調(diào)用 DeepSeek API,實(shí)現(xiàn)流式對(duì)話并保存對(duì)話記錄。相比 Go 版本,Python 實(shí)現(xiàn)更加簡(jiǎn)潔優(yōu)雅,適合快速開(kāi)發(fā)和原型驗(yàn)證。https://cloud.siliconflow.cn/i/vnCCfVaQ
1. 環(huán)境準(zhǔn)備
1.1 依賴安裝
pip install requests
1.2 項(xiàng)目結(jié)構(gòu)
deepseek-project/ ├── main.py # 主程序 └── conversation.txt # 對(duì)話記錄文件
2. 完整代碼實(shí)現(xiàn)
import os import json import time import requests from datetime import datetime def save_to_file(file, content, is_question=False): """保存對(duì)話內(nèi)容到文件""" timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S") if is_question: file.write(f"\n[{timestamp}] Question:\n{content}\n\n[{timestamp}] Answer:\n") else: file.write(content) def main(): # 配置 url = "https://api.siliconflow.cn/v1/chat/completions" headers = { "Content-Type": "application/json", "Authorization": "Bearer YOUR_API_KEY" # 替換為你的 API Key } # 打開(kāi)文件用于保存對(duì)話 with open("conversation.txt", "a", encoding="utf-8") as file: while True: # 獲取用戶輸入 question = input("\n請(qǐng)輸入您的問(wèn)題 (輸入 q 退出): ").strip() if question.lower() == 'q': print("程序已退出") break # 保存問(wèn)題 save_to_file(file, question, is_question=True) # 準(zhǔn)備請(qǐng)求數(shù)據(jù) data = { "model": "deepseek-ai/DeepSeek-V3", "messages": [ { "role": "user", "content": question } ], "stream": True, "max_tokens": 2048, "temperature": 0.7, "top_p": 0.7, "top_k": 50, "frequency_penalty": 0.5, "n": 1, "response_format": { "type": "text" } } try: # 發(fā)送流式請(qǐng)求 response = requests.post(url, json=data, headers=headers, stream=True) response.raise_for_status() # 檢查響應(yīng)狀態(tài) # 處理流式響應(yīng) for line in response.iter_lines(): if line: line = line.decode('utf-8') if line.startswith('data: '): if line == 'data: [DONE]': continue try: content = json.loads(line[6:]) # 去掉 'data: ' 前綴 if content['choices'][0]['delta'].get('content'): chunk = content['choices'][0]['delta']['content'] print(chunk, end='', flush=True) file.write(chunk) file.flush() except json.JSONDecodeError: continue # 添加分隔符 print("\n----------------------------------------") file.write("\n----------------------------------------\n") file.flush() except requests.RequestException as e: error_msg = f"請(qǐng)求錯(cuò)誤: {str(e)}\n" print(error_msg) file.write(error_msg) file.flush() if __name__ == "__main__": main()
3. 代碼詳解
3.1 核心功能
文件記錄功能
save_to_file
函數(shù)負(fù)責(zé):
- 生成時(shí)間戳
- 格式化保存問(wèn)題和答案
- 自動(dòng)刷新文件緩沖區(qū)
API 配置
headers = { "Content-Type": "application/json", "Authorization": "Bearer YOUR_API_KEY" # 替換為你的 API Key }
流式請(qǐng)求處理
程序使用 requests
庫(kù)的流式處理功能:
- 使用
stream=True
啟用流式傳輸 - 逐行處理響應(yīng)數(shù)據(jù)
- 實(shí)時(shí)顯示和保存內(nèi)容
3.2 配置參數(shù)說(shuō)明
API 請(qǐng)求參數(shù):
model
: 使用的模型名稱stream
: 啟用流式輸出max_tokens
: 最大輸出長(zhǎng)度 (2048)temperature
: 控制隨機(jī)性 (0.7)top_p
,top_k
: 采樣參數(shù)frequency_penalty
: 重復(fù)懲罰系數(shù)
4. 錯(cuò)誤處理
代碼包含完整的錯(cuò)誤處理機(jī)制:
- 檢查 HTTP 響應(yīng)狀態(tài)
- 捕獲網(wǎng)絡(luò)異常
- 處理 JSON 解析錯(cuò)誤
- 文件操作錯(cuò)誤處理
5. 使用方法
5.1 修改配置
在代碼中替換 YOUR_API_KEY 為你的實(shí)際 API Key。
5.2 運(yùn)行程序
python main.py
5.3 交互方式
- 輸入問(wèn)題進(jìn)行對(duì)話
- 輸入 ‘q’ 退出程序
- 查看 conversation.txt 獲取對(duì)話記錄
6. 性能優(yōu)化建議
文件操作
- 使用適當(dāng)?shù)木彌_區(qū)大小
- 定期刷新文件緩沖
- 正確關(guān)閉文件句柄
網(wǎng)絡(luò)請(qǐng)求
- 設(shè)置適當(dāng)?shù)某瑫r(shí)
- 使用會(huì)話(Session)復(fù)用連接
- 處理網(wǎng)絡(luò)異常
內(nèi)存管理
- 及時(shí)釋放資源
- 避免大量數(shù)據(jù)積累
- 使用生成器處理流式數(shù)據(jù)
總結(jié)
Python 版本的 DeepSeek API 調(diào)用實(shí)現(xiàn)簡(jiǎn)單直觀,適合快速開(kāi)發(fā)和測(cè)試。通過(guò)流式處理和文件記錄,提供了完整的對(duì)話體驗(yàn)。
到此這篇關(guān)于Python調(diào)用DeepSeek API的完整操作指南的文章就介紹到這了,更多相關(guān)Python調(diào)用DeepSeek API內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 如何使用?Python?實(shí)現(xiàn)?DeepSeek?R1?本地化部署
- Python使用Flask結(jié)合DeepSeek開(kāi)發(fā)(實(shí)現(xiàn)代碼)
- Python調(diào)用DeepSeek?API的案例詳細(xì)教程
- python使用django調(diào)用deepseek api搭建ai網(wǎng)站
- Python結(jié)合DeepSeek API實(shí)現(xiàn)PDF轉(zhuǎn)Word的方案
- Python與DeepSeek的深度融合實(shí)戰(zhàn)
- Python使用DeepSeek進(jìn)行聯(lián)網(wǎng)搜索功能詳解
- python+ollama自己寫代碼調(diào)用本地deepseek模型
相關(guān)文章
pyqt5 實(shí)現(xiàn)在別的窗口彈出進(jìn)度條
今天小編就為大家分享一篇pyqt5 實(shí)現(xiàn)在別的窗口彈出進(jìn)度條,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06Python pandas遍歷行數(shù)據(jù)的2種方法小結(jié)
pandas在數(shù)據(jù)處理過(guò)程中,除了對(duì)整列字段進(jìn)行處理之外,有時(shí)還需求對(duì)每一行進(jìn)行遍歷,本文就來(lái)介紹Python pandas遍歷行數(shù)據(jù)的2種方法小結(jié),感興趣的可以了解一下2024-03-03python 命名規(guī)范知識(shí)點(diǎn)匯總
這里給大家分享的是在python開(kāi)發(fā)過(guò)程中需要注意的命名的規(guī)范的知識(shí)匯總,有需要的小伙伴可以查看下2020-02-02瘋狂上漲的Python 開(kāi)發(fā)者應(yīng)從2.x還是3.x著手?
熱度瘋漲的 Python,開(kāi)發(fā)者應(yīng)從 2.x 還是 3.x 著手?這篇文章就為大家分析一下了Python開(kāi)發(fā)者應(yīng)從2.x還是3.x學(xué)起,感興趣的小伙伴們可以參考一下2017-11-11Python 3.6 讀取并操作文件內(nèi)容的實(shí)例
下面小編就為大家分享一篇Python 3.6 讀取并操作文件內(nèi)容的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Python并發(fā)concurrent.futures和asyncio實(shí)例
這篇文章主要介紹了Python并發(fā)concurrent.futures和asyncio實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05python使用pip成功導(dǎo)入庫(kù)后還是報(bào)錯(cuò)的解決方法(針對(duì)vscode)
最近在學(xué)爬蟲,但在使用Scrapy包時(shí),在終端通過(guò)pip裝好包以后,在pycharm中導(dǎo)入包時(shí),依然會(huì)報(bào)錯(cuò),下面這篇文章主要給大家介紹了關(guān)于python使用pip成功導(dǎo)入庫(kù)后還是報(bào)錯(cuò)的解決方法,需要的朋友可以參考下2022-07-07Python下使用Trackbar實(shí)現(xiàn)繪圖板
這篇文章主要為大家詳細(xì)介紹了Python下使用Trackbar實(shí)現(xiàn)繪圖板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10