使用Rapid API中的OpenAI API,创建您自己的ChatGPT。

在人工智能领域,OpenAI的ChatGPT已经成为一个强大的工具,用于创建对话代理。借助RapidAI中OpenAI的API的能力,我们可以构建自己的聊天机器人。在本文中,我们将探讨一个简单而有效的代码段,并演示如何使用它与ChatGPT进行有意义的对话交流。

创建自己的ChatGPT涉及将提示信息发送到Rapid API的OpenAI API,并接收响应。让我们深入了解代码:

import requests
import json

这些行导入了用于发起HTTP请求(requests)和处理JSON数据(json)的必要模块。

def get_gpt_response(prompt):
url = "https://open-ai21.p.rapidapi.com/conversationgpt35"

querystring = {"text": prompt, "language": "en"}

payload = {
"messages": [
{
"role": "user",
"content": prompt
}
],
"web_access": False,
"system_prompt": "",
"temperature": 0.9,
"top_k": 5,
"top_p": 0.9,
"max_tokens": 256
}
headers = {
"content-type": "application/json",
"X-RapidAPI-Key": "Use api from rapidacAPI",
"X-RapidAPI-Host": "open-ai21.p.rapidapi.com"
}

response = requests.post(url, json=payload, headers=headers)

return response.json()

该函数名为get_gpt_response,接受一个参数prompt,代表用户的输入或消息。该函数旨在与OpenAI GPT API交互以获取响应。url变量存储RapidAPI提供的OpenAI Conversation GPT的API端点。querystring使用参数创建,包括在API请求中包括的参数。它指定了用户的输入(文本)和语言(英文为en)。负载是一个包含GPT模型的各种设置和数据的字典。它包括一系列消息,其中用户的输入被指定为内容。其他参数,如web_access(设置为False)、system_prompt、temperature、top_k、top_p和max_tokens控制生成过程中模型行为的各个方面。

  • web_access(网络访问):若设置为True,则允许对模型进行网络访问,但在本案例中,它被设为False(假)。
  • system_prompt:这是一个模型的系统级指令,在本例中留空。
  • 温度:控制模型输出的随机性。较高的值(例如0.9)会产生更随机的输出。
  • top_k:指定在“top-k”抽样中考虑的令牌数量。
  • top_p:表示“核心”采样的累积概率。
  • max_tokens:限制生成的回复长度。

headers 字典包含了制作API请求所需的信息。"content-type" 指定了负载以JSON格式发送,而 "X-RapidAPI-Key" 和 "X-RapidAPI-Host" 分别提供了API密钥和主机详情。请注意, 您需要将占位符替换为实际的API密钥。这个 responsepart 使用负载和头部发送了一个POST请求到指定的URL (url)。然后,响应将通过 response.json() 转换为一个Python字典,并由这个函数返回。

尝试使用不同的提示来了解模型的反应情况。

input = "What is python?"
output = get_gpt_response(input)["result"]

print(output)

让我们将其与HTML和Python代码集成,创建一个功能性的网络应用程序。

index.html and app.py 代码

<!-- index.html-->
<!-- Tasrif Nur Himel -->


<!DOCTYPE html>
<html lang="en">

<head>
<meta charset=UTF-8 <meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">

<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200" />
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Poppins:wght@300&display=swap" rel="stylesheet">
<title>Chatbot</title>

<style>

*{
padding: 0;
margin: 0;
font-family: 'Poppins', sans-serif;
box-sizing: border-box;
}

body{
width: 100%;
height: 100vh;
background-color: #33343f;
}

.chat{
display: flex;
gap: 20px;
padding: 25px;
color: #fff;
font-size: 15px;
font-weight: 300;
}

.chat img{
width: 35px;
height: 35px;
}

.response{
background-color: #494b59;
}

.messagebar{
position: fixed;
bottom: 0;
height: 5rem;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
border-top: 1px solid #494b59;
background-color: #33343f;
}

.messagebar .bar-wrapper{
background-color: #494b59;
border-radius: 5px;
width: 60vw;
padding: 10px;
display: flex;
align-items: center;
justify-content: space-between;
}

.bar-wrapper input{
width: 100%;
padding: 5px;
border: none;
outline: none;
font-size: 14px;
background: none;
color: #ccc;
}

.bar-wrapper input::placeholder{
color: #ccc;
}

.messagebar button{
display: flex;
align-items: center;
justify-content: center;
background: none;
border: none;
color: #fff;
cursor: pointer;
}

.message-box{
height: calc(100vh - 5rem);
overflow-y: auto;
}



</style>
</head>

<body>
<div class="chatbox-wrapper">
<div class="message-box">
<div class="chat response">
<img src="" alt="Himel">
<span>Hello there! <br>
How can I help you today.
</span>
</div>
</div>
<div class="messagebar">
<div class="bar-wrapper">
<input id="user-input" type="text" placeholder="Enter your message...">
<button onclick="sendMessage()">
<span class="material-symbols-rounded">
send
</span>
</button>
</div>
</div>
</div>

<script>
function sendMessage() {
const userInput = document.getElementById('user-input');
const userMessage = userInput.value.trim();

if (userMessage !== '') {
const chatbox = document.querySelector('.message-box');
const messageDiv = document.createElement('div');
messageDiv.classList.add('chat', 'user');
messageDiv.innerHTML = `<img src="https://images.crunchbase.com/image/upload/c_thumb,h_170,w_170,f_auto,g_faces,z_0.7,b_white,q_auto:eco,dpr_1/tcy3rckwzjkgiwukthin"><span>${userMessage}</span>`;
chatbox.appendChild(messageDiv);

// Clear input field
userInput.value = '';

// Send user message to Flask backend
fetch('/api/gpt-response', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
prompt: userMessage
}),
})
.then(response => response.json())
.then(data => {
const botMessage = data.result;
const botMessageDiv = document.createElement('div');
botMessageDiv.classList.add('chat', 'response');
botMessageDiv.innerHTML = ` <img src="" alt="Himel"><span>${botMessage}</span>`;
chatbox.appendChild(botMessageDiv);
})
.catch(error => console.error('Error:', error));
}
}
</script>
</body>

</html>

# app.py
# Tasrif Nur Himel

from flask import Flask, request, jsonify,render_template
import requests

app = Flask(__name__)

@app.route('/')
def render_html():
return render_template('index.html')

@app.route('/api/gpt-response', methods=['POST'])
def get_gpt_response():
prompt = request.json['prompt']
url = "https://open-ai21.p.rapidapi.com/conversationgpt35"

payload = {
"messages": [
{"role": "user", "content": prompt}
],
"web_access": False,
"system_prompt": "",
"temperature": 0.9,
"top_k": 5,
"top_p": 0.9,
"max_tokens": 256
}

headers = {
"content-type": "application/json",
"X-RapidAPI-Key": "Use Your Api",
"X-RapidAPI-Host": "open-ai21.p.rapidapi.com"
}

response = requests.post(url, json=payload, headers=headers)
result = response.json().get("result", "Sorry, I couldn't understand that.")

return jsonify({"result": result})

if __name__ == '__main__':
app.run(debug=True)

根据app.py中的render_template函数,如果你的HTML文件名为"index.html",请确保它被放置在与app.py相同目录下名为"templates"的文件夹内。以下是文件夹结构:

This photo made by “Tasrif Nur Himel”

理解代码

现在,让我们来分解这个整合的解决方案:

  • app.py:这个Python脚本使用Flask创建了一个简单的Web服务器。它包含了先前代码中的get_gpt_response函数。/chat端点接收用户消息,将其发送给ChatGPT,并返回助手的回复。
  • index.html: 这个 HTML 文件提供了一个基本的聊天界面。它包括一个输入框供用户输入消息,并且有一个按钮用于将消息发送给服务器。JavaScript 函数处理用户输入、显示消息,并与服务器进行通信。

结论

通过将提供的后端和前端代码与ChatGPT API结合,您已经创建了一个功能完备的聊天机器人应用程序。这为将对话式人工智能集成到各种项目中打开了无尽的可能性。实验、定制,并释放您个性化ChatGPT聊天机器人的力量!

作者:Tasrif Nur Himel 热情洋溢的机器学习工程师,来自孟加拉国

关注我的Github账号:https://github.com/Himel-Tasrif

2024-01-09 04:39:32 AI中文站翻译自原文