将 Gemini 与 OpenAI 库结合使用

碧海醫心
发布: 2024-11-11 15:03:01
转载
1142人浏览过

将 gemini 与 openai 库结合使用

基于这篇文章,我们现在可以将 gemini 与 openai 库一起使用。所以,我决定在这篇文章中尝试一下

目前仅提供聊天完成 api 和嵌入 api。

在本文中,我尝试使用 python 和 javascript。

python

首先,我们来搭建环境。

pip install openai python-dotenv
登录后复制

接下来,让我们运行以下代码。

import os

from dotenv import load_dotenv
from openai import openai


load_dotenv()
google_api_key = os.getenv("google_api_key")

client = openai(
    api_key=google_api_key,
    base_url="https://generativelanguage.googleapis.com/v1beta/"
)


response = client.chat.completions.create(
    model="gemini-1.5-flash",
    n=1,
    messages=[
        {"role": "system", "content": "you are a helpful assistant."},
        {
            "role": "user",
            "content": "explain briefly(less than 30 words) to me how ai works."
        }
    ]
)

print(response.choices[0].message.content)
登录后复制

返回了以下响应。

ai mimics human intelligence by learning patterns from data, using algorithms to solve problems and make decisions. 
登录后复制

在内容字段中,您可以指定字符串或“类型”:“文本”。

import os

from dotenv import load_dotenv
from openai import openai


load_dotenv()
google_api_key = os.getenv("google_api_key")

client = openai(
    api_key=google_api_key,
    base_url="https://generativelanguage.googleapis.com/v1beta/"
)

response = client.chat.completions.create(
    model="gemini-1.5-flash",
    n=1,
    messages=[
        {"role": "system", "content": "you are a helpful assistant."},
        {
            "role": "user",
            "content": [
                {
                    "type": "text",
                    "text": "explain briefly(less than 30 words) to me how ai works.",
                },
            ]
        }
    ]
)

print(response.choices[0].message.content)
登录后复制

但是,图像和音频输入出现错误。

图像输入示例代码

import os

from dotenv import load_dotenv
from openai import openai


load_dotenv()
google_api_key = os.getenv("google_api_key")

client = openai(
    api_key=google_api_key,
    base_url="https://generativelanguage.googleapis.com/v1beta/"
)

# png to base64 text
import base64
with open("test.png", "rb") as image:
    b64str = base64.b64encode(image.read()).decode("utf-8")

response = client.chat.completions.create(
    model="gemini-1.5-flash",
    # model="gpt-4o",
    n=1,
    messages=[
        {"role": "system", "content": "you are a helpful assistant."},
        {
            "role": "user",
            "content": [
                {
                    "type": "text",
                    "text": "describe the image in the image below.",
                },
                {
                    "type": "image_url",
                    "image_url": {
                        "url": f"data:image/png;base64,{b64str}"
                    }
                }
            ]
        }
    ]
)

print(response.choices[0].message.content)
登录后复制

音频输入示例代码

import os

from dotenv import load_dotenv
from openai import openai


load_dotenv()
google_api_key = os.getenv("google_api_key")

client = openai(
    api_key=google_api_key,
    base_url="https://generativelanguage.googleapis.com/v1beta/"
)

# png to base64 text
import base64
with open("test.wav", "rb") as audio:
    b64str = base64.b64encode(audio.read()).decode("utf-8")

response = client.chat.completions.create(
    model="gemini-1.5-flash",
    # model="gpt-4o-audio-preview", 
    n=1,
    modalities=["text"],
    messages=[
        {"role": "system", "content": "you are a helpful assistant."},
        {
            "role": "user",
            "content": [
                {
                    "type": "text",
                    "text": "what does he say?",
                },
                {
                    "type": "input_audio",
                    "input_audio": {
                        "data": b64str,
                        "format": "wav",
                    }
                }
            ]
        }
    ]
)

print(response.choices[0].message.content)
登录后复制

返回了以下错误响应。

openai.badrequesterror: error code: 400 - [{'error': {'code': 400, 'message': 'request contains an invalid argument.', 'status': 'invalid_argument'}}]
登录后复制

目前仅支持文字输入,不过后续似乎会支持图片和音频输入。

javascript

让我们看一下 javascript 示例代码。

首先,我们来搭建环境。

npm init -y
npm install openai
npm pkg set type=module
登录后复制

接下来,让我们运行以下代码。

import openai from "openai";

const google_api_key = process.env.google_api_key;
const openai = new openai({
    apikey: google_api_key,
    baseurl: "https://generativelanguage.googleapis.com/v1beta/"
});

const response = await openai.chat.completions.create({
    model: "gemini-1.5-flash",
    messages: [
        { role: "system", content: "you are a helpful assistant." },
        {
            role: "user",
            content: "explain briefly(less than 30 words) to me how ai works",
        },
    ],
});

console.log(response.choices[0].message.content);
登录后复制

运行代码时,请确保在 .env 文件中包含 api 密钥。 .env 文件将在运行时加载。

node --env-file=.env run.js
登录后复制

返回了以下响应。

AI systems learn from data, identify patterns, and make predictions or decisions based on those patterns.
登录后复制

我们可以在同一个库中使用其他模型,这真是太棒了。

就我个人而言,我对此感到很高兴,因为 openai 使编辑对话历史记录变得更加容易。

以上就是将 Gemini 与 OpenAI 库结合使用的详细内容,更多请关注php中文网其它相关文章!

豆包AI编程
豆包AI编程

智能代码生成与优化,高效提升开发速度与质量!

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号