广告
返回顶部
首页 > 资讯 > 精选 >怎么使用ChatGPT搭建AI网站
  • 929
分享到

怎么使用ChatGPT搭建AI网站

2023-07-05 19:07:38 929人浏览 薄情痞子
摘要

这篇文章主要介绍“怎么使用ChatGPT搭建ai网站”,在日常操作中,相信很多人在怎么使用ChatGPT搭建AI网站问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用ChatGPT搭建AI网站”的疑惑有所

这篇文章主要介绍“怎么使用ChatGPT搭建ai网站”,在日常操作中,相信很多人在怎么使用ChatGPT搭建AI网站问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用ChatGPT搭建AI网站”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1.概述

ChatGPT是一款基于GPT-3.5架构的大型语言模型,它能够进行自然语言处理和生成对话等任务。作为一款智能化的聊天机器人,ChatGPT有着广泛的应用场景,如在线客服、智能助手、个性化推荐等。今天笔者给大家分享一下如何使用ChatGPT的api模型快速搭建一个AI网站。

2.内容

在实战中,我发现ChatGPT的最大优势在于其自然流畅的对话交互能力。ChatGPT能够自动理解用户的意图和提出的问题,并针对性地给出回答和建议。同时,它还可以基于已有的上下文信息生成更加丰富的回复,从而实现更加自然和贴近人类的交互效果。

下面我将分享一些关于如何使用ChatGPT的实战经验,大概流程如下所示:

怎么使用ChatGPT搭建AI网站

在使用ChatGPT前,我们需要对数据进行预处理。预处理的目的是将原始文本转换为模型可以理解的格式。具体来说,需要进行的预处理步骤包括:分词、标记化、向量化等。这些步骤都可以使用常见的NLP工具库来实现,如NLTK、spaCy、transfORMers等。在预处理完数据后,我们需要使用训练数据来训练ChatGPT模型。通常情况下,我们会使用一些优秀的深度学习框架来实现模型的训练,如PyTorchTensorflow等。在模型训练过程中,我们需要设置一些超参数,如学习率、批量大小、模型深度等。在模型训练完成后,我们需要对模型进行评估。评估的目的是了解模型的性能和表现,从而决定是否需要进行进一步的调整和优化。常见的模型评估指标包括:准确率、召回率、F1值等。在完成模型训练和评估后,我们需要将ChatGPT应用到实际场景中。通常情况下,我们需要将ChatGPT集成到我们的应用程序中,如在线客服、智能助手等。在部署过程中,我们需要考虑一些问题,如性能、可靠性、安全性等。

3.如何使用ChatGPT快速实现一个AI网站呢?

使用ChatGPT实现一个AI网站,大概步骤如下所示:

怎么使用ChatGPT搭建AI网站

首先,您需要确定您的AI网站将用于哪些目的和哪些受众。您的目标可能是提供在线客服、智能问答、语音识别、自动翻译等功能。您的受众可能是您的客户、读者、访问者等。通过明确您的目标和受众,您可以更好地规划您的网站架构和设计。要构建一个AI网站,您需要选择一个web开发框架。常用的WEB开发框架包括Djangoflask、Express等。这些框架提供了许多常见的功能和模板,可以帮助您更快速地开发网站,并提高开发效率。集成ChatGPT是实现AI网站的关键步骤。您可以使用pythonjavascript编程语言来调用ChatGPT API并将其嵌入到您的Web应用程序中。这样,您的网站就可以通过ChatGPT提供更好的用户体验和服务。例如,用户可以通过与ChatGPT交互来获取问题的答案、进行语音交互等。

为了让用户能够更好地与ChatGPT交互,您需要创建一个用户友好的界面。您可以使用htmlCSS、JavaScript等技术来设计和创建您的用户界面。您需要考虑到用户的需求和体验,并确保您的界面简洁、易用、美观等。为了让ChatGPT能够准确地回答用户的问题,您需要对ChatGPT进行训练。您可以使用自然语言处理技术来训练ChatGPT,以便它能够理解和响应用户的问题。您可以使用开源的数据集和算法来训练ChatGPT,并优化模型以提高精度和效率。

在将您的网站部署到生产环境之前,您需要对它进行测试和优化。您应该检查所有功能并确保它们能够正常运行,同时还应该优化性能和用户体验,以提高用户满意度。您可以使用自动化测试工具来测试您的网站,并使用性能分析工具来识别瓶颈和优化点。您可以收集用户反馈并进行改进,以不断改善您的网站。

当您准备好将您的网站部署到生产环境时,您需要选择一个合适的Web服务器数据库。常用的Web服务器包括Apache、Nginx等,常用的数据库包括MySQLpostgresql等。您还需要选择一个合适的云服务提供商,如AWS、Google Cloud等,并将您的应用程序部署到云服务器上。一旦您的网站部署到生产环境,您需要进行定期的维护和升级。您应该定期备份您的数据并更新您的应用程序以确保安全性和稳定性。您还应该持续地优化您的用户体验和功能,以满足用户的需求和期望。

4.基于promptable快速实现

如果你不懂算法,那么可以通过在promptable 快速建立prompt,然后部署生成一个PromptID,通过这个PromptID直接调用OpenAI的接口得到模型输出的结果。操作如下:

4.1 编写一个hook模块

用来调用OpenAI的接口,获取输出结果,实现代码如下所示:

import { addMessage, getHistoryString } from "@/utils/chatHistory";import React, { useEffect } from "react";export const useChatGpt = (message, promptId, chatHistory) => {  // Send user meesage to api, meesage and prompt in body  // then update state value with response  //   console.log("Hook api call", message, promptId);  const [data, setData] = React.useState("");  const [isLoading, setIsLoading] = React.useState(false);  const [isError, setIsError] = React.useState(false);  const [history, setHistory] = React.useState(chatHistory);  const [isSuccess, setIsSuccess] = React.useState(false);  const fetchData = async () => {    setIsLoading(true);    try {      const response = await fetch("/api/chatgpt", {        method: "POST",        headers: {          "Content-Type": "application/JSON",        },        body: jsON.stringify({          message,          promptId,          chatHistory: getHistoryString(chatHistory),        }),      }).then((res) => res.json());      if (response.reply) {        console.log("Hook api call response", response.reply);        setData(response.reply);        setIsSuccess(true);        setHistory(addMessage(chatHistory, response.reply, "agent"));      } else {        setIsError(true);      }    } catch (error) {      setIsError(true);    }    setIsLoading(false);  };  useEffect(() => {    setIsError(false);    setIsSuccess(false);    if (message) {      fetchData();    }  }, [message]);  useEffect(() => {    setHistory(chatHistory);  }, [chatHistory]);  useEffect(() => {    if (promptId) {      setIsError(false);      setIsSuccess(false);      setHistory([]);    }  }, [promptId]);  return {    data,    isLoading,    isError,    history,    isSuccess,  };};

通过编写一个页面组件,用来实现与后台接口服务交互使用,该模块用来调用模型并得到输出结果,实现代码如下所示:

import { useChatGpt } from "@/hook/useChatGpt";import { addMessage } from "@/utils/chatHistory";import { Button, TextField } from "@mui/material";import React, { useEffect } from "react";import { ChatHistoryFrame } from "./ChatHistoryFrame";const promptId = "xxxxxx"; // 通过Prompt自动生成获取IDexport const ChatContainer = () => {  const [pendingMessage, setPendingMessage] = React.useState("");  const [message, setMessage] = React.useState("");  const [chatHistory, setChatHistory] = React.useState([]);  const { isLoading, history, isSuccess, isError } = useChatGpt(    message,    promptId,    chatHistory  );  useEffect(() => {    if (isSuccess || isError) {      setMessage("");    }  }, [isSuccess, isError]);  return (    <div>        <h2>MOVIE to emoji</h2>      </a>      <ChatHistoryFrame chatHistory={chatHistory} isLoading={isLoading} />      <div>        <TextField          type="text"          onChange={(e) => {            setPendingMessage(e.target.value);          }}        />        <Button          style={{            backgroundColor: "black",            width: "80px",          }}          variant="contained"          onClick={() => {            setMessage(pendingMessage);            setChatHistory(addMessage(history || [], pendingMessage, "user"));          }}        >          Send        </Button>        <Button          style={{            color: "black",            width: "80px",            borderColor: "black",          }}          variant="outlined"          onClick={() => {            setMessage("");            setChatHistory([]);          }}        >          Clear        </Button>      </div>    </div>  );};

编写一个调用ChatGPT接口逻辑的核心模块,用来与API交互得到输出结果,具体实现细节如下:

import { PromptableApi } from "promptable";import { Configuration, OpenAIApi } from "openai";import GPT3Tokenizer from "gpt3-tokenizer";const configuration = new Configuration({  apiKey: process.env.OPENAI_API_KEY,});const openai = new OpenAIApi(configuration);const tokenizer = new GPT3Tokenizer({ type: "gpt3" });const chatgpt = async (req, res) => {  const { message, promptId, chatHistory } = req.body;  console.log("api call entry", message, promptId);  if (!message) {    res.status(400).json({ error: "Message is required" });    return;  }  if (!promptId) {    res.status(400).json({ error: "Prompt ID is required" });    return;  }  // call prompt ai api and openai api  const reply = await getReply(message, promptId, chatHistory || "");  res.status(200).json({ reply });  return;};const getReply = async (message, promptId, chatHistory) => {  // get prompt from prompt ai api based on promptId  if (!promptId) {    throw new Error("Prompt ID is required");  }  const promptDeployment = await PromptableApi.getActiveDeployment({    promptId: promptId,  });  console.log("prompt deployment", promptDeployment);  if (!promptDeployment) {    throw new Error("Prompt deployment not found");  }  // replace prompt with message  const beforeChatHistory = promptDeployment.text.replace("{{input}}", message);  const numTokens = countBPETokens(beforeChatHistory);  const afterChatHistory = beforeChatHistory.replace(    "{{chat history}}",    chatHistory  );  const finalPromptText = leftTruncateTranscript(    afterChatHistory,    4000 - numTokens  );  const revisedPrompt = {    ...promptDeployment,    text: finalPromptText,  };  console.log("revised prompt", revisedPrompt);  // call openai api  const response = await openai.createCompletion({    model: revisedPrompt.config.model,    prompt: revisedPrompt.text,    temperature: revisedPrompt.config.temperature,    max_tokens: revisedPrompt.config.max_tokens,    top_p: 1.0,    frequency_penalty: 0.0,    presence_penalty: 0.0,    stop: revisedPrompt.config.stop,  });  console.log("openai response", response.data);  if (response.data.choices && response.data.choices.length > 0) {    return response.data.choices[0].text;  } else {    return "I'm sorry, I don't understand.";  }};function countBPETokens(text) {  const encoded = tokenizer.encode(text);  return encoded.bpe.length;}function leftTruncateTranscript(text, maxTokens) {  const encoded = tokenizer.encode(text);  const numTokens = encoded.bpe.length;  const truncated = encoded.bpe.slice(numTokens - maxTokens);  const decoded = tokenizer.decode(truncated);  return decoded;}export default chatgpt;

最后,我们工程所使用的依赖包,如下所示:

"dependencies": {    "@emotion/react": "^11.10.5",    "@emotion/styled": "^11.10.5",    "@mui/material": "^5.11.6",    "@next/font": "13.1.6",    "eslint": "8.32.0",    "eslint-config-next": "13.1.6",    "gpt3-tokenizer": "^1.1.5",    "next": "13.1.6",    "openai": "^3.2.1",    "promptable": "^0.0.5",    "react": "18.2.0",    "react-dom": "18.2.0"  }

在完成核心模块的后台逻辑编写后,可以访问Prompt后台,通过编写Prompt来获取ID,操作如下:

怎么使用ChatGPT搭建AI网站

4.2 部署Prompt

完成Prompt编写后,我们就可以部署Prompt了,部署成功后会生成一个PromptID,如下图所示:

怎么使用ChatGPT搭建AI网站

 这里,在部署Prompt里面有参考代码实现,具体如下:

import axiOS from 'axios'// 这里面的xxxxxxx是部署Prompt自动生成的ID,这里我用xxxxxxx替换了const { data } = await axios.get('https://promptable.ai/api/prompt/xxxxxxx/deployment/active')const prompt = data.inputs?.reduce((acc, input) => {  // Replace input.value with your value!  return acc.replaceAll(`{{${input.name}}}, ${input.value}`)}, data.text)const res = await axios.get('Https://openai.com/v1/completions', {  data: {    // your prompt    prompt,    // your model configs from promptable    config: {      ...data.config,      // add any other configs here    }  }})// Your completion!console.log(res.data.choices[0].text)

最后,我们基于OpenAI最新的gpt-3.5-turbo模型,开发一个AI网站,效果如下:

怎么使用ChatGPT搭建AI网站

 这里为了节省token费用,通过点击“停止对话”按钮暂时输出了。因为使用OpenAI的接口是按照token来算费用的,英文字母算一个token,一个汉字算两个token,收费明细如下:

怎么使用ChatGPT搭建AI网站

到此,关于“怎么使用ChatGPT搭建AI网站”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么使用ChatGPT搭建AI网站

本文链接: https://www.lsjlt.com/news/354728.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么使用ChatGPT搭建AI网站
    这篇文章主要介绍“怎么使用ChatGPT搭建AI网站”,在日常操作中,相信很多人在怎么使用ChatGPT搭建AI网站问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用ChatGPT搭建AI网站”的疑惑有所...
    99+
    2023-07-05
  • 如何使用ChatGPT搭建AI网站
    1.概述 ChatGPT是一款基于GPT-3.5架构的大型语言模型,它能够进行自然语言处理和生成对话等任务。作为一款智能化的聊天机器人,ChatGPT有着广泛的应用场景,如在线客服、...
    99+
    2023-05-13
    ChatGPT搭建AI网站 把ChatGPT部署到自己网站服务器 ChatGPT用1分钟搭建一个网站
  • 怎么使用PHP搭建网站
    本文小编为大家详细介绍“怎么使用PHP搭建网站”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用PHP搭建网站”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。确定您的需求:在开始搭建网站之前,您需要确定您的需...
    99+
    2023-07-05
  • 怎么用python搭建网站
    要使用Python搭建网站,可以使用一个Python的Web框架,例如Django或Flask。下面是使用Flask框架搭建网站的基本步骤:1. 安装Flask:在终端或命令提示符中,输入以下命令安装Flask:```pip insta...
    99+
    2023-08-11
    python
  • 使用asp主机怎么搭建网站
    1. 选择一个ASP主机服务商,注册一个域名并购买主机空间。2. 登录主机控制面板,在网站管理中创建一个新的网站。3. 上传网站文件...
    99+
    2023-06-03
    asp主机 主机
  • 怎么使用magento主机搭建网站
    以下是使用Magento主机搭建网站的步骤:1. 购买Magento主机:选择一家可靠的Magento主机提供商,并根据需要选择合适...
    99+
    2023-06-03
    magento主机 主机
  • 怎么使用wordpress空间搭建网站
    以下是使用WordPress空间搭建网站的步骤:1. 购买WordPress空间并登录控制面板首先,您需要购买WordPress空间...
    99+
    2023-06-03
    wordpress空间 空间
  • azure怎么搭建网站
    使用azure搭建网站的方法首先,进入azure操作界面,点击“创建网站”,选择“自定义创建”;在自定义创建页面中,填写网站域名等信息,等待网站创建完成;网站创建成功后,进入网站,选择“仪表盘”选项;在仪表盘界面中,查找到ftp账号信息,并...
    99+
    2022-10-24
  • oss怎么搭建网站
    oss搭建网站的步骤:申请一个域名。开通OSS并创建Bucket。开通OSS的静态网站托管功能。使用自定义域名访问OSS即可。...
    99+
    2022-10-14
  • gitee怎么搭建网站
    随着互联网技术的不断发展,越来越多的人开始在网络中寻求信息、娱乐甚至商业机会。在这样的背景下,网站成为人们获取信息和展示自我形象的最重要的工具之一。但是,建立一个网站需要很多前期的准备工作, 尤其是对于初学者来说,很多工具和概念都会让人感到...
    99+
    2023-10-22
  • 怎么搭建WORDPRESS网站
    今天就跟大家聊聊有关怎么搭建WORDPRESS网站,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。WORDPRESS是目前为止世界上最为流行的程序之一,拥有功能强大。扩展性强等弄能,因...
    99+
    2023-06-07
  • vps试用怎么搭建网站
    以下是在VPS上搭建网站的基本步骤:1. 在VPS上安装Web服务器软件,如Apache、Nginx等。2. 配置Web服务器,使其...
    99+
    2023-06-14
    vps试用 vps
  • VPS云主机使用怎么搭建网站
    要搭建网站,首先需要选择合适的VPS云主机,然后按照以下步骤进行操作:1. 安装LAMP环境:LAMP环境包括Linux、Apach...
    99+
    2023-06-04
    VPS云主机 VPS 云主机
  • 怎么使用虚拟主机搭建网站
    使用虚拟主机搭建网站需要以下步骤:1. 购买虚拟主机:选择一个可靠的虚拟主机提供商,并根据需要选择合适的虚拟主机套餐。建议选择支持P...
    99+
    2023-06-10
    虚拟主机
  • GO怎么样搭建网站
    GO使用http.HandleFunc()方法搭建一个网站程序,具体方法如下:使用http.HandleFunc()方法获取参数,并保存为 hello.go文件;package mainimport ("io""log""net/http"...
    99+
    2022-10-09
  • python怎么搭建web网站
    要搭建一个Web网站,你可以使用Python的一些框架来简化开发过程。以下是一些流行的Python Web框架:1. Django:...
    99+
    2023-09-08
    python
  • 用iis搭建网站怎么关闭
    用iis搭建网站的关闭方法:打开计算机控制面板 → 系统和安全 → 管理工具 → 服务 → 找到iis服务,右键将其关闭即可。...
    99+
    2022-10-15
  • 怎么用win7的IIS搭建网站
    用win7的IIS搭建网站操作步骤:点击win7桌面的开始菜单 → 选择管理工具 → internet信息服务管理,点击打开。点击列表中本地计算机展开下拉菜单 → 右键“网站” → 新建网站。 输入网址描述,点击下一步。 填写网址相关信息,...
    99+
    2022-10-13
  • 网站建设系统怎么搭建
    网站建设系统的搭建需要以下步骤:1.选择合适的建站平台:根据自己的需求和技术水平选择合适的建站平台,例如WordPress、Wix、...
    99+
    2023-06-08
    网站建设系统 网站建设
  • 使用云主机搭建网站怎么设置
    搭建网站的具体设置步骤会因不同的操作系统、Web服务器和网站类型而有所不同。以下是一些搭建网站的一般步骤:1. 选择云主机:选择适合...
    99+
    2023-06-07
    云主机搭建网站 云主机
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作