自己实现 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

完结!

相关推荐
爱听歌的周童鞋39 分钟前
Harness Engineering 到底是什么?概念、实战与争议,一次全部讲清楚
openai·agent·anthropic·engineering·harness
掘金酱15 小时前
📱 TRAE SOLO 移动端上线征文|“我的第一次移动端AI办公” 评测,赢机械键盘礼包+10w矿石!
openai·ai编程·trae
机器之心16 小时前
DeepSeek版Claude Code登顶热榜:8700星,鲸鱼哥火了
人工智能·openai
前端阿彬17 小时前
OpenGeno开源库:Spec 总在腐烂?我用一棵树 + 一个 hook 解决了它
openai·ai编程·claude
程序员老廖20 小时前
校招C++20并发系列05-突破生产者-消费者瓶颈:双缓冲无锁设计实战
openai
程序员老廖20 小时前
校招C++20并发系列08-安全生产多线程队列:并发容器替代STL实战
openai
win4r1 天前
🚀开发者必看!Codex /goal命令你真用对了吗?goal命令高级技巧保姆级教程,Plan模式+Spec-Driven+自研Skill,三大高级技巧组合让
openai·ai编程·vibecoding
IT当时语_青山师__JAVA技术栈1 天前
DeepSeek V4 出来了,我一个 Java 老炮第一时间接进 Spring Boot——附 V3 vs V4 实测对比
gpt·openai·deepseek
冬奇Lab1 天前
一天一个开源项目(第93篇):Symphony - OpenAI 官方定义的 AI 代理编排规范
人工智能·openai·agent
小兵张健2 天前
Codex 需要手机号验证?一招教你破局!
程序员·openai·ai编程