client = OpenAI(
api_key="MOONSHOT_API_KEY",
base_url="https://api.moonshot.cn/v1"
)

api_key用于驗證用戶身份,這里要將 MOONSHOT_API_KEY 替換為自己從 Kimi開放平臺:

https://platform.moonshot.cn/console/api-keys

申請的API Key。

base_url?參數用于指定API客戶端庫(如OpenAI SDK)與哪個服務器的API端點進行通信。當我們使用OpenAI SDK來調用Moonshot AI的API時,需要將?base_url?從Open AI的API端點”https://api.openai.com/v1″替換為Moonshot AI的API端點”https://api.moonshot.cn/v1″,這樣SDK才能正確地將請求發送到Moonshot AI的服務器。

調用代碼如下:

def chat_kimi(problem):

system_content = "你是一位語言藝術大師" # 設置系統消息,可以在這里定義聊天機器人的初始狀態或規則

user_content = problem # 用戶的輸入

assistant_content = " " # 初始化聊天機器人的回答為空白

# 發送請求到Moonshot AI的API
response = client.chat.completions.create(
model="moonshot-v1-8k", # <-- 指定使用的模型,根據需要選擇合適的模型
messages=[
{"role": "system", "content": system_content},
{"role": "user", "content": user_content},
{"role": "assistant", "content": assistant_content}
],
temperature=0.5, # 控制回答的隨機性,其值越趨于1隨機性越大
max_tokens=1024, # 最大返回的token數量
)
return response.choices[0].message.content

print(f"Kimi:{chat_kimi(input("user:"))}")

對于非stream,response響應的內容格式:

ChatCompletion(
id='chatcmpl-673f770075b744800cd80585',
choices=[
Choice(
finish_reason='stop',
index=0,
logprobs=None,
message=ChatCompletionMessage(
role='assistant',
content='你好!很高興和你交流。我是Kimi,來自月之暗面科技有限公司開發的Moonshot AI。有什么可以幫助你的嗎?',
))],
created=1732212480,
model='moonshot-v1-8k',
object='chat.completion',
usage=CompletionUsage(completion_tokens=28, prompt_tokens=16, total_tokens=44))

所以上述調用我們使用response.choices[0].message.content來返回有效的信息。

同步調用的機制流程圖如下:

異步調用

異步調用是一種非阻塞式的調用方式,客戶端發起請求后,不會立即等待服務器的響應,而是繼續執行其他操作。當服務器處理完請求并返回結果時,客戶端再通過回調函數或其他機制來處理響應結果。

為實現異步調用,我們使用HTTP客戶端庫aiohttp。以下是安裝aiohttp庫的命令:

pip install aiohttp

調用代碼如下:

import aiohttp
import asyncio

async def chat_kimi(problem):
api_key = "MOONSHOT_API_KEY"
base_url = "https://api.moonshot.cn/v1"
model = "moonshot-v1-8k"
headers = { #定義一個字典,用于存儲HTTP請求的頭部信息
"Authorization": f"Bearer {api_key}", #使用Bearer令牌進行身份驗證
"Content-Type": "application/json" #告訴服務器發送的數據是JSON格式
}
system_content = " "
payload = {
"model": model,
"messages": [
{"role": "system", "content": system_content},
{"role": "user", "content": problem}
],
"temperature": 0.5,
"max_tokens": 1024
}

async with aiohttp.ClientSession() as session:
async with session.post(f"{base_url}/chat/completions", headers=headers, json=payload) as response:
if response.status == 200:
data = await response.json()
return data
else:
raise Exception(f"Request failed with status {response.status}")
#查詢響應內容
print(asyncio.run(chat_kimi("你好")))

response響應的內容:

異步調用的機制流程圖如下:

SSE調用

SSE是一種允許服務器主動向客戶端發送數據的技術。在這種調用方式中,客戶端建立一個持久的HTTP連接,服務器可以在任何時候通過這個連接向客戶端實時發送數據。

調用代碼如下:

import aiohttp
import asyncio
import json

async def sse_request(problem):
api_key = "sk-njKietCYs1p8yG7Q87rcgQlrp5yDTZRurZa5abgtkyde1OfI"
base_url = "https://api.moonshot.cn/v1/chat/completions"
headers = {
"Authorization": f"Bearer {api_key}",
"Content-Type": "application/json",
"Accept": "text/event-stream" #告訴服務器客戶端期望接收SSE格式的數據
}
system_content = " "
data = {
"model": "moonshot-v1-128k",
"messages": [
{"role": "system", "content": system_content},
{"role": "user", "content": problem}
],
"temperature": 0.8,
"stream": True,
}

async with aiohttp.ClientSession() as session:
async with session.post(base_url, headers=headers, json=data) as response:
if response.status != 200:
raise Exception(await response.text())

async for line in response.content:
line = line.strip()
if not line:
continue # 忽略空行

# 將字節對象轉換為字符串
line_str = line.decode('utf-8')

if line_str.startswith("data: "):
line_str = line_str[6:] # 移除 "data: " 前綴
if line_str == "[DONE]":
break # 結束符,結束循環

# 處理數據塊
try:
chunk = json.loads(line_str)
choice = chunk.get("choices", [{}])[0]
delta = choice.get("delta", {})
content = delta.get("content")
if content:
print(content, end='')
except json.JSONDecodeError:
print("Error decoding JSON:", line_str)
asyncio.run(sse_request("講個冷笑話吧"))

response響應的內容格式:

SSE調用的機制流程圖:

OK啊~就到這吧,寫不下去了,總結一下。

總結

本文就簡單介紹了一下三種調用Kimi API的方式,同步、異步、SSE,每種方式都有其適用的場景和特點:

同步調用

使用場景:適合順序執行的任務,或者客戶端可以暫停等待結果的場景。

行為特性:簡單直觀,容易實現和調試。但是,如果服務器響應慢,客戶端會處于空閑等待狀態,效率較低。

異步調用

使用場景:適合處理大量并發請求,或者需要提高客戶端響應速度的場景。

行為特性:提高了程序的效率和響應速度,但邏輯相對復雜,需要處理異步邏輯和回調

SSE調用

使用場景:適合需要服務器實時推送數據到客戶端的場景,如實時消息更新、股票價格變動等。

行為特性:實現了輕量級的實時通信,只需要使用標準的HTTP協議。但僅支持服務器到客戶端的單向通信。

區別

阻塞性:同步調用是阻塞性的,客戶端必須等待響應;異步調用是非阻塞性的,客戶端在等待響應時可以繼續執行其他任務;SSE調用也是非阻塞性的,并且可以持續接收服務器的推送。

實時性:同步調用和異步調用通常用于請求-響應模式,不保證實時性;SSE調用則允許服務器實時推送數據到客戶端。

復雜性:同步調用通常最容易理解和實現;異步調用增加了實現的復雜性,需要處理異步邏輯;SSE調用雖然邏輯簡單,但需要服務器支持SSE規范。

適用場景:同步調用適合簡單的請求-響應模式;異步調用適合需要高并發處理的應用程序;SSE調用適合需要服務器實時更新數據的應用程序。

注意點

API Key安全:請確保自己的API Key安全,不要泄露給他人,以免造成不必要的損失。

請求限制:請遵守Moonshot AI的使用條款和請求頻率限制,以免請求被拒絕。

本文章轉載微信公眾號@LIT科研小分隊

熱門推薦
一個賬號試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊
3000+提示詞助力AI大模型
和專業工程師共享工作效率翻倍的秘密
返回頂部
上一篇
長文本大模型API服務kimi-free-api
下一篇
大模型接口管理和分發系統One API
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
91老师国产黑色丝袜在线| 久久精品久久综合| 日本一区二区电影| 亚洲一区二区3| 欧美午夜电影在线播放| 亚洲精品第一国产综合野| 成人久久视频在线观看| 国产欧美精品一区aⅴ影院| 国产裸体歌舞团一区二区| 国产三级欧美三级| 99久久精品免费看国产| 亚洲欧美一区二区三区孕妇| 在线观看一区二区精品视频| 亚洲国产视频直播| 日韩女优av电影在线观看| 国内精品嫩模私拍在线| 国产精品国产三级国产aⅴ原创| 成人99免费视频| 午夜影院久久久| 精品国产91亚洲一区二区三区婷婷| 国内成+人亚洲+欧美+综合在线| 国产精品无码永久免费888| 色婷婷亚洲一区二区三区| 奇米色一区二区| 国产精品久久久久毛片软件| 欧美日韩亚洲综合一区二区三区| 久久成人久久鬼色| 亚洲四区在线观看| 精品国产乱码久久久久久影片| 91在线观看高清| 九九视频精品免费| 一区二区三区免费网站| 国产亚洲精品久| 日韩欧美国产成人一区二区| 在线亚洲欧美专区二区| 高清av一区二区| 久久草av在线| 日韩精品亚洲一区二区三区免费| 国产视频一区二区在线| 欧美一级免费观看| 欧美性xxxxxxxx| 91视频国产资源| 大尺度一区二区| 韩国精品一区二区| 麻豆成人91精品二区三区| 亚洲免费在线观看视频| 久久精品亚洲麻豆av一区二区 | 精品国精品自拍自在线| 欧美在线色视频| 日本乱码高清不卡字幕| 成人激情午夜影院| 成人av第一页| 91丨porny丨户外露出| www.99精品| 色哟哟日韩精品| 欧美日韩国产高清一区二区三区 | 一区二区三区成人| 亚洲乱码中文字幕| 午夜精品一区二区三区免费视频| 亚洲精品日日夜夜| 亚洲国产精品欧美一二99| 一区二区免费在线| 日韩1区2区日韩1区2区| 久久精品国产99| 国产成人在线免费| 91亚洲精品一区二区乱码| 色婷婷精品大在线视频| 欧美日韩精品综合在线| 日韩欧美不卡一区| 国产农村妇女毛片精品久久麻豆| 国产精品每日更新| 亚洲影院理伦片| 久久se这里有精品| 91女神在线视频| 51精品国自产在线| 亚洲国产激情av| 亚洲不卡一区二区三区| 韩国v欧美v亚洲v日本v| 97久久精品人人爽人人爽蜜臀| 色婷婷av一区二区三区软件| 欧美一区二区国产| 国产精品女同一区二区三区| 亚洲综合av网| 国产成a人亚洲| 欧美精三区欧美精三区| 久久精品视频在线看| 一区二区三区四区亚洲| 久久99久久久欧美国产| 欧美在线制服丝袜| 亚洲欧美综合另类在线卡通| 日本午夜精品一区二区三区电影| 九九九精品视频| 欧美视频一区在线| 最好看的中文字幕久久| 麻豆成人av在线| 欧美人伦禁忌dvd放荡欲情| 国产精品卡一卡二卡三| 激情综合五月婷婷| 欧美一级视频精品观看| 亚洲一区二区中文在线| 成人h精品动漫一区二区三区| 日韩免费电影一区| 青青草伊人久久| 欧美高清视频www夜色资源网| 亚洲欧美视频一区| 99精品视频在线观看| 国产亚洲一本大道中文在线| 精品写真视频在线观看| 日韩一区二区麻豆国产| 日韩黄色片在线观看| 欧美肥妇bbw| 午夜激情一区二区| 欧美一区二区播放| 免费人成精品欧美精品| 欧美mv日韩mv国产网站app| 麻豆精品久久久| 欧美成人精精品一区二区频| 蜜臀av性久久久久蜜臀aⅴ| 日韩精品中文字幕一区二区三区| 蜜臀av一区二区在线观看| 久久综合九色综合97婷婷| 国内外成人在线| 国产欧美一区二区精品婷婷| 国产98色在线|日韩| 亚洲欧美视频在线观看视频| 99久久久久免费精品国产| 亚洲黄色录像片| 在线不卡a资源高清| 日韩av不卡一区二区| 精品国产免费一区二区三区香蕉| 国产精品一区在线观看你懂的| 久久精品亚洲麻豆av一区二区| 99re8在线精品视频免费播放| 亚洲国产日韩精品| 欧美精品一区二区三区高清aⅴ | 欧美精品国产精品| 韩国av一区二区三区四区| 国产精品久久免费看| 欧美日本乱大交xxxxx| 国产伦精品一区二区三区免费迷| 国产精品第五页| 91麻豆精品久久久久蜜臀| 99久久精品国产精品久久| 亚洲福利视频一区二区| 久久久久九九视频| 欧美三级视频在线| 国产精品18久久久久久vr| 一区二区不卡在线播放| 久久久午夜精品| 欧美日韩精品一区二区三区| 不卡一二三区首页| 精品在线免费观看| 亚洲18女电影在线观看| 国产精品激情偷乱一区二区∴| 欧美一区二区成人| 96av麻豆蜜桃一区二区| 国产一区二区看久久| 日韩精品一区第一页| 樱花影视一区二区| 中文字幕一区二区三区色视频 | yourporn久久国产精品| 精品一区二区三区欧美| 一区二区三区av电影| 国产精品欧美精品| 亚洲精品一线二线三线| 日韩一区和二区| 91精品免费在线| 欧美精品日韩综合在线| 91成人免费网站| 91麻豆福利精品推荐| 成人黄色一级视频| 风间由美一区二区三区在线观看| 久久97超碰色| 老汉av免费一区二区三区| 日韩精品免费专区| 奇米色一区二区三区四区| 免费观看在线综合色| 奇米色一区二区| 乱中年女人伦av一区二区| 久久草av在线| 国产麻豆精品theporn| 精品一区二区三区的国产在线播放 | av在线这里只有精品| 不卡欧美aaaaa| 色综合天天狠狠| 欧美日韩午夜在线视频| 日韩一区二区影院| 久久久精品2019中文字幕之3| 久久午夜国产精品| 国产精品久久久久一区| 一区二区三区不卡视频| 亚洲成av人片在线| 老司机精品视频在线| 丁香婷婷综合网| 在线免费观看不卡av| 精品视频一区三区九区| 日韩欧美美女一区二区三区| 国产欧美一区二区精品秋霞影院| 一区二区三区资源| 国产呦萝稀缺另类资源|