探索AI前沿:本地部署GPT-4o,打造专属智能助手!

2024-06-22 10:28

本文主要是介绍探索AI前沿:本地部署GPT-4o,打造专属智能助手!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、获取API_key

2、开始调用

3、openai连接异常

4、解决方法:

5、调用GPT-4o


1、获取API_key

这里就不多赘述了,大家可以参考下面这篇博客

怎么获取OpenAI的api-key【人工智能】icon-default.png?t=N7T8https://blog.csdn.net/qq_51625007/article/details/137632747

2、开始调用

有了第一步的API_key,就可以直接调用GPT-4o,不说废话,直接上代码

import base64
from PIL import Image
import os
import io
from openai import OpenAI
from dotenv import load_dotenv
load_dotenv('.env')# 这一步很关键
import os
os.environ["http_proxy"] = "http://localhost:51121"
os.environ["https_proxy"] = "http://localhost:51121"client = OpenAI(api_key='sk-xxxxxxxxxx')def encode_image(image):buffered = io.BytesIO()image.save(buffered, format=image.format)return base64.b64encode(buffered.getvalue()).decode('utf-8')def extract_image(query, image_file=None):messages = [{"role": "user", "content": [{"type": "text", "text": query}]}]if image_file is not None:image = Image.open(image_file)base64_image = encode_image(image)image_message = {"type": "image_url","image_url": {"url": f"data:image/jpeg;base64,{base64_image}"}}messages[0]["content"].append(image_message)response = client.chat.completions.create(model="gpt-4o",messages=messages,max_tokens=1024)return response.choices[0].message.contentif __name__ == "__main__":result = extract_image(query="图中有什么?",image_file="./截图20240621225613.png")print(result)

3、openai连接异常

raise APIConnectionError(request=request) from err openai.APIConnectionError

报错解释:

openai.APIConnectionError 是 OpenAI 的 Python 客户端在尝试连接到 OpenAI 服务器时遇到问题时抛出的异常。这通常表明客户端无法建立与服务器的连接,可能是由于网络问题、服务器宕机、API 密钥无效或过期等原因造成的。

解决方法:

  1. 检查网络连接:确保你的设备可以正常访问互联网。

  2. 检查 OpenAI 服务状态:访问 OpenAI 的官方网站或状态监控页面,查看是否有服务中断或维护通知。

  3. 检查 API 密钥:确保你使用的 API 密钥有效且未过期。

  4. 代理设置:如果你使用代理连接到互联网,确保你的代理设置正确配置,并且代理服务器运行正常。

逐个问题排查,最终确定是代理设置问题

4、解决方法:

本文是在window11中执行:

按照----->设置----->网络和Internet----->代理----->打开代理即可

点击设置:代理IP地址和端口(这里每个人的电脑端口可能不一样),将这两个在代码里指定如下:localhost或者127.0.0.1都可以!

但是如果只设置这两个可能还不行,需要再增加一个load_doten使用.env文件去设置环境变量,将OPEN_API_KEY的值保存在.env文件中。

pip install python-dotenv #安装
# 这一步很关键
import os
from dotenv import load_dotenv
load_dotenv('.env')
os.environ["http_proxy"] = "http://localhost:51121"
os.environ["https_proxy"] = "http://localhost:51121"

5、调用GPT-4o

prompt="图中有什么?"

图中是一本讲解编程或计算机科学相关内容的书籍的某个页面。页面标题为“第2章 语言可用性的强化”,并且讨论了“空值”以及在C++中的使用。页面的内容包括以下几部分:

1. **章节标题**:
   ```
   第2章 语言可用性的强化
   ```

2. **小节标题**:
   ```
   2.1 常量
   nullptr
   ```

3. **文本说明和代码片段**:
   - 文中详细讲解了nullptr的背景与使用。
   - 提到了传统C++中的NULL以及其在现代C++中的替代 `nullptr`。
   - 展示了代码示例,演示了如何使用 `nullptr` 避免一些常见的错误。
   - 包含了多个C++代码片段,例如:
     ```cpp
     char *ch = NULL;
     void foo(char*);
     void foo(int);
     foo(NULL);
     #include <iostream>
     #include <type_traits>
     void foo(char*);
     void foo(int);
     int main() {
         if (std::is_same<decltype(NULL), decltype(0)>::value)
             std::cout << "NULL == 0" << std::endl;
         if (std::is_same<decltype(NULL), decltype((void*)0)>::value)
             std::cout << "NULL == (void *)0" << std::endl;
         if (std::is_same<decltype(NULL), std::nullptr_t>::value)
             std::cout << "NULL == nullptr" << std::endl;
     }
     ```

4. **页面底部的页码**:
   ```
   12
   ```

以上就是该页面的主要内容。

这篇关于探索AI前沿:本地部署GPT-4o,打造专属智能助手!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084029

相关文章

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

SpringBoot配置Ollama实现本地部署DeepSeek

《SpringBoot配置Ollama实现本地部署DeepSeek》本文主要介绍了在本地环境中使用Ollama配置DeepSeek模型,并在IntelliJIDEA中创建一个Sprin... 目录前言详细步骤一、本地配置DeepSeek二、SpringBoot项目调用本地DeepSeek前言随着人工智能技

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

CentOS 7部署主域名服务器 DNS的方法

《CentOS7部署主域名服务器DNS的方法》文章详细介绍了在CentOS7上部署主域名服务器DNS的步骤,包括安装BIND服务、配置DNS服务、添加域名区域、创建区域文件、配置反向解析、检查配置... 目录1. 安装 BIND 服务和工具2.  配置 BIND 服务3 . 添加你的域名区域配置4.创建区域

Spring AI ectorStore的使用流程

《SpringAIectorStore的使用流程》SpringAI中的VectorStore是一种用于存储和检索高维向量数据的数据库或存储解决方案,它在AI应用中发挥着至关重要的作用,本文给大家介... 目录一、VectorStore的基本概念二、VectorStore的核心接口三、VectorStore的

OpenManus本地部署实战亲测有效完全免费(最新推荐)

《OpenManus本地部署实战亲测有效完全免费(最新推荐)》文章介绍了如何在本地部署OpenManus大语言模型,包括环境搭建、LLM编程接口配置和测试步骤,本文给大家讲解的非常详细,感兴趣的朋友一... 目录1.概况2.环境搭建2.1安装miniconda或者anaconda2.2 LLM编程接口配置2

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

在VSCode中本地运行DeepSeek的流程步骤

《在VSCode中本地运行DeepSeek的流程步骤》本文详细介绍了如何在本地VSCode中安装和配置Ollama和CodeGPT,以使用DeepSeek进行AI编码辅助,无需依赖云服务,需要的朋友可... 目录步骤 1:在 VSCode 中安装 Ollama 和 CodeGPT安装Ollama下载Olla