自己实现 OpenAI 的 /v1/embeddings 接口

自己实现 OpenAI 的 /v1/embeddings 接口

  • [0. 背景](#0. 背景)
  • [1. 修改 .env 文件](#1. 修改 .env 文件)
  • [2. 修改 get_embedding 方法](#2. 修改 get_embedding 方法)

0. 背景

使用 OpenAI 的 API Key 是需要付费的,为了节省成本,自己尝试实现 OpenAI 的各种接口。

本文章主要是实现 /v1/embeddings/v1/engines/{model_name}/embeddings 接口的部分代码示例。

1. 修改 .env 文件

添加 COHERE_API_KEY,

复制代码
COHERE_API_KEY='abcdeOuJIC5scu0dB6TJW0CijNMDP5tHfu8u2xyz' # 此 key 无效

2. 修改 get_embedding 方法

复制代码
async def get_embedding(payload: Dict[str, Any]):
    # print(f"payload: {payload}")
    cohere_payload = {"texts": payload["input"], "truncate": "END"}
    # print(f"cohere_payload: {cohere_payload}")
    # print(f"os.environ['COHERE_API_KEY']: {os.environ['COHERE_API_KEY']}")
    cohere_headers = {
        'Accept': 'application/json',
        'Authorization': 'Bearer ' + os.environ['COHERE_API_KEY'],
        'Content-Type': 'application/json',
    }
    # print(f"cohere_headers: {cohere_headers}")
    async with httpx.AsyncClient() as client:
        # https://docs.cohere.com/reference/embed
        response = await client.post(
            "https://api.cohere.ai/v1/embed",
            headers=cohere_headers,
            json=cohere_payload,
            timeout=WORKER_API_TIMEOUT,
        )
        # print(f"response: {response}")
        cohere_embeddings = response.json()
        # print(f"cohere_embeddings: {cohere_embeddings}")
        embedding = {"embedding": cohere_embeddings["embeddings"], "token_num": 1}
        return embedding

完结!

相关推荐
机器之心14 小时前
OpenAI也搞「Mythos」?网络安全版GPT-5.4-Cyber亮相
人工智能·openai
量子位15 小时前
新Vidu Q3参考生,这是冲着「剧」来的!万物皆可参考:特效音效场景都备好了
openai
慧知AI15 小时前
Chrome Skills重磅上线!浏览器秒变"龙虾助理",开发者必看
openai
量子位15 小时前
刚刚,李飞飞世界模型新成果发布
openai
無名路人16 小时前
用 codex AI 更新了下之前写的浏览器云书签标签页扩展
前端·openai·ai编程
加瓦点灯21 小时前
从 Prompt 到 Harness:AI 工程的三重进化,你在哪一层?
openai
Rubin智造社1 天前
4月14日AI每日参考:Claude Code配额告急,Gemma 4开源可跑手机
openai·google deepmind·claude mythos·ai每日参考·claude code配额·斯坦福ai指数
量子位2 天前
不只是卖服务器,中兴通讯想做AI时代的基础设施商
openai·ai编程
量子位2 天前
死敌爆料是狠!OpenAI内部信阴阳Claude营收注水80亿,然后泄露了…
openai·claude
snow_yan2 天前
AI 对话流式输出: 实现“逐字丝滑、不闪烁、不卡顿”的打字机效果
前端·react.js·openai