aisuite
大家好,我是玩机器学习的章北海
早上看到吴恩达老师的新推文,他开源了一个最新的 Python 包——aisuite
aisuite
是干什么的呢?一句话总结:
“面向多个生成式人工智能提供商的简单、统一的接口”
aisuite
使开发者能够通过标准化接口轻松使用多个大语言模型(LLM)。它采用类似于OpenAI
的接口,让开发者能够方便地与最流行的大语言模型进行交互并比较结果。
它是围绕Python
客户端库的一个轻量级包装,允许创作者在不更改代码的情况下无缝切换和测试来自不同 LLM 提供商的响应。目前,这个库主要专注于聊天补全功能,未来将扩展以涵盖更多用例。
安装与使用
安装
pip install aisuite
设置 api_key
export OPENAI_API_KEY="your-openai-api-key"
export ANTHROPIC_API_KEY="your-anthropic-api-key"
使用
import aisuite as ai
client = ai.Client()
models = ["openai:gpt-4o", "anthropic:claude-3-5-sonnet-20240620"]
messages = [
{"role": "system", "content": "Respond in Pirate English."},
{"role": "user", "content": "Tell me a joke."},
]
for model in models:
response = client.chat.completions.create(
model=model,
messages=messages,
temperature=0.75
)
print(response.choices[0].message.content)
在调用 create() 时模型名称使用格式“ <提供商> : <模型名称> ”。
要获取提供商值列表,可以查看目录“aisuite/providers/”
当前支持的提供商包括OpenAI、Anthropic、Azure、Google、AWS、Groq、Mistral、HuggingFace、Ollama
。为了最大限度地提高稳定性,aisuite
使用HTTP
端点或SDK
来调用提供商的服务。
说点别的
其实市面上早就大模型中间代理商,提供的也有统一的api
调用方式,可以直接使用 N 多不同厂商的大模型。
比如我多次推荐的、适合国内使用的siliconflow
地址:https://cloud.siliconflow.cn?referrer=cly7ai3ir000jqab7qaqp0qwf
它不但完美支持OpenAI API
调用,还可以免费使用Qwen、GLM、Yi
等模型。
调用方式:
from openai import OpenAI
client = OpenAI(api_key="YOUR_API_KEY", base_url="https://api.siliconflow.cn/v1")
response = client.chat.completions.create(
model='deepseek-ai/DeepSeek-V2.5',
messages=[
{'role': 'user',
'content': "SiliconCloud 推出分层速率方案与免费模型 RPM 提升 10 倍,对于整个大模型应用领域带来哪些改变?"}
],
stream=True
)
for chunk in response:
print(chunk.choices[0].delta.content, end='')
还有海外的openroute
,提供了 277 个大模型的 api 调用
地址:https://openrouter.ai/docs/quick-start
调用方式:
from openai import OpenAI
client = OpenAI(
base_url="https://openrouter.ai/api/v1",
api_key="$OPENROUTER_API_KEY",
)
completion = client.chat.completions.create(
extra_headers={
"HTTP-Referer": $YOUR_SITE_URL, // Optional, for including your app on openrouter.ai rankings.
"X-Title": $YOUR_APP_NAME, // Optional. Shows in rankings on openrouter.ai.
},
model="openai/gpt-3.5-turbo",
messages=[
{
"role": "user",
"content": "What is the meaning of life?"
}
]
)
print(completion.choices[0].message.content)