【2024最全最细Langchain教程-1 】调用openai实现人工智能时代的hello_world

 环境准备:

1. 安装python3.10(其他版本亦可,不要低于3.8)

2. 找一个文件夹,建立一下python的虚拟环境

python -m venv .venv #创建虚拟的python环境

.\.venv\Scripts\activate #进入虚拟环境并激活

2. 进入虚拟环境后,安装jupyter开发环境 (前期教学最好用,后期大项目要安装pycharm)

pip install jupyter

3. 激活jupyter工具,这是一个在浏览器上运行的开发工具,进入地址为 localhost:8888

jupyter notebook

进行openai的调用:

1. 安装和引入需要用的包和openai库

     安装openai的库,注意安装之后,jupyter要彻底重启才能加载

pip install openai
import os
from openai import OpenAI

2. 创建一个OpenAI的对象

        填入openai调用所需的key,将这个实例命名为 client,这里建议把key配置到系统环境变量里然后再用 os.getenv()方法进行调用,不会泄密。(如何配置可以B站搜“AI小万老师”看视频更方便,这里不多赘述)

client = OpenAI(
    # 此处需要填入openai的key,可以直接填入,但建议最好可以配置到本地环境变量中
    # api_key ='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'
   
    api_key = os.getenv("OPENAI_API_KEY")

    #需要账号的可以加我微信免费试用,15652965525
)

3. 调用openai的内置方法,输入消息和模型选择

chat_completion = client.chat.completions.create(
    messages=[
        {
            "role": "user",
            "content": "hello world是什么意思,为什么这个短语很有名?",
        }
    ],
    model="gpt-3.5-turbo",
)

response = chat_completion.choices

# print(response)

print(response[0].message.content)

一切顺利的话会有如下输出:

4. 没有openai官方账号可以站内私信联系我,只需要添加两行代码也可达到访问openai的效果

client = OpenAI(
    # 重新注册账号,生成一个新的key,配置进系统环境
    api_key= os.getenv("OPENAI_API_KEY") ,
    # 这里将官方的接口访问地址,替换成国内节点的入口地址
    base_url="https://wdapi7.61798.cn/v1"
)

5. 可使用其他大模型,比如HUGGINGFACE上有免费模型,但是效果不佳,大家可以自行测试

import os
from huggingface_hub import InferenceClient

client = InferenceClient(token = os.getenv("HUGGINGFACE_API_KEY"))
response = client.post(json={"inputs": "中国的首都在哪儿?"}, model="google/flan-t5-xxl")

print(response)

本教学演示代码已上传github: https://github.com/jerry1900/jupyter

本教学有B站视频,欢迎大家捧场:调用openai实现我们的hello_world_哔哩哔哩_bilibili

### 回答1: async-http-client 是一个用于发送 HTTP 请求的异步非阻塞的 Java 客户端库。而 OpenAI 则是一个提供人工智能服务的平台。如果我们需要使用 async-http-client 调用 OpenAI 接口,可以按照以下步骤进行操作: 1. 首先,我们需要引入 async-http-client 库。可以通过 Maven 或 Gradle 将其添加到项目的依赖中。 2. 接下来,我们需要获取 OpenAI 平台提供的 API 密钥,这个密钥将用于进行身份验证。 3. 在代码中,我们需要构建一个 HttpClient 实例,这个实例将负责发送 HTTP 请求。可以使用 async-http-client 提供的自定义配置选项,设置连接超时时间、最大连接数等。 4. 然后,我们需要构建一个 Request 对象,指定请求的 URL、请求方法、请求头等信息。在这个 Request 对象中,我们可以添加请求的参数,例如可以将需要处理的数据通过请求的 body 发送给 OpenAI 接口。 5. 使用 HttpClient 的 `executeRequest` 方法发送请求。这个方法是异步的,它会立即返回一个 `Future<Response>` 对象。 6. 我们可以通过调用 `getResponse` 方法来获取异步请求的结果。这个方法会一直阻塞,直到请求的结果返回。 7. 最后,我们可以对请求结果进行处理,例如提取返回的数据或者进行错误处理。 使用 async-http-client 调用 OpenAI 接口需要注意以下几点:确保 API 密钥正确且有效、设置合适的请求参数、合理处理请求的返回结果。另外,可能还需要参考 OpenAI 提供的 API 文档,了解具体的接口使用方法和参数要求。 通过将 async-http-client 和 OpenAI 结合使用,我们可以更方便地在 Java 中使用 OpenAI 提供的人工智能服务,实现各种智能化的功能。 ### 回答2: async-http-client是一个基于Java的异步HTTP客户端,它提供了一个简单而强大的方式来进行HTTP请求和处理响应。那么如何使用async-http-client来调用openai接口呢? 首先,你需要在项目中导入async-http-client的依赖,可以通过Maven或Gradle等构建工具来进行安装和配置。 接下来,你需要创建一个HTTP客户端实例。你可以通过AsyncHttpClient类的构造函数来实现,如下所示: ```java AsyncHttpClient client = new DefaultAsyncHttpClient(); ``` 然后,你需要构建一个HTTP请求。对于openai接口,你可以使用HttpGet或HttpPost等类来发送GET或POST请求。假设你要发送一个GET请求,你可以这样构建: ```java Request request = new RequestBuilder().setUrl("https://api.openai.com/your-endpoint") .setMethod("GET") .build(); ``` 然后,你可以通过client的execute方法来发送请求并获取响应,如下所示: ```java ListenableFuture<Response> future = client.executeRequest(request); ``` 你可以通过添加回调函数来处理响应,比如成功时的回调函数onCompleted、失败时的回调函数onThrowable等。例如,你可以这样处理响应: ```java future.addListener(() -> { try { Response response = future.get(); // 处理响应数据 } catch (InterruptedException | ExecutionException e) { // 处理异常 } }, executor); ``` 最后,你可以在onCompleted回调函数中处理openai接口的响应数据。你可以通过使用response类的方法来获取HTTP响应的状态码、头部信息和响应体等。例如,你可以这样获取响应体: ```java String responseBody = response.getResponseBody(); ``` 这样,你就可以使用async-http-client来调用openai接口了。记得在使用完毕后关闭客户端资源,以释放相关的资源: ```java client.close(); ``` 这只是async-http-client的基本用法,你还可以根据具体的需求和openai接口的要求进行进一步的定制和扩展。 ### 回答3: async-http-client 是一个用于异步发送 HTTP 请求的 Java 库。可以通过该库来调用 openai 接口,可以实现异步发送请求并获取响应的功能。 首先,需要使用 async-http-client 的 API 创建一个 HTTP 客户端。然后,通过该客户端发送 HTTP 请求到 openai 接口的 URL。可以在请求中设置必要的请求头信息,如 token、content-type 等。可以使用 POST 方法发送数据,将需要传递给 openai 接口的参数作为请求体发送。 在发送请求后,async-http-client 会异步地等待 openai 接口的响应。可以通过设置回调函数来处理异步响应,在回调函数中可以对接口的响应进行处理,如获取响应的状态码、响应体等信息。 当接收到 openai 接口的响应后,可以根据需要进行相应的处理,如解析响应体的数据,进行数据处理或展示。若需要发送更多的请求,可以重复以上步骤。 需要注意的是,调用 openai 接口时可能会出现网络连接异常、超时等问题,可以通过 async-http-client 提供的错误处理机制来处理这些问题,如设置超时时间、重试次数等。 总之,使用 async-http-client 可以很方便地调用 openai 接口,并且实现异步发送请求和获取响应的功能,使得请求过程更加高效和可靠。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值