如何优化大型 JSON 文件以与 ChatGPT API 一起使用?
来源:dev.to
2025-01-23 09:39:54
0浏览
收藏
本篇文章向大家介绍《如何优化大型 JSON 文件以与 ChatGPT API 一起使用?》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。
我正在尝试使用 chatgpt 作为我的 magento 2 网站的聊天机器人,并且我想将产品数据传递给它。为此,我收集了所有产品并将它们存储在一个 json 文件中,然后读取该文件以将数据嵌入到系统角色的 systemrolecontent 中。然而,我面临的问题是 json 文件相当大。
{ "bot_response": "error: chatbot error: unexpected api response structure: {\n \"error\": {\n \"message\": \"request too large for gpt-4o on tokens per min (tpm): limit 30000, requested 501140. the input or output tokens must be reduced in order to run successfully. visit https://platform.openai.com/account/rate-limits to learn more.\",\n \"type\": \"tokens\",\n \"param\": null,\n \"code\": \"rate_limit_exceeded\"\n }\n}\n" }
我注意到需要在 api 配置中添加一个功能,该功能允许您运行查询来根据名称或描述中与用户消息中的关键字匹配的关键字来选择产品。挑战在于用户最初可能不知道产品的名称;他们来到聊天机器人是为了发现他们。我该如何解决这个问题?
这是我现在正在使用的代码:
<?php namespace MetaCares\Chatbot\Model; use Magento\Framework\App\ObjectManager; class ChatBot { private $authorization; private $endpoint; private $conversationHistory = []; private $productsFile; private $fetchingDateFile; private $didFetchProducts = false; public function __construct() { $this->authorization = 'sk-proj-'; $this->endpoint = 'https://api.openai.com/v1/chat/completions'; $this->productsFile = __DIR__ . '/products.json'; $this->fetchingDateFile = __DIR__ . '/fetching_date.json'; $currentTime = time(); $timeDifferenceSeconds = 24 * 3600; if (!file_exists($this->fetchingDateFile)) { file_put_contents($this->fetchingDateFile, json_encode(['last_fetch_time' => 0])); } $fetchingData = json_decode(file_get_contents($this->fetchingDateFile), true); $lastFetchTime = $fetchingData['last_fetch_time'] ?? 0; if ($currentTime - $lastFetchTime > $timeDifferenceSeconds) { $products = $this->fetchProductsUsingModel(); $productsJson = json_encode($products); file_put_contents($this->productsFile, $productsJson); $fetchingData['last_fetch_time'] = $currentTime; file_put_contents($this->fetchingDateFile, json_encode($fetchingData)); $this->didFetchProducts = true; } $jsonSampleData = file_get_contents($this->productsFile); $systemRoleContent = <<<EOT Nom: Meta Cares Bot Description BOT Meta Cares répond aux questions sur les produits du site et fournit des conseils santé fiables. Tu aides les clients de Meta Cares à faire des choix éclairés tout en offrant un accompagnement personnalisé, sécurisé et adapté à leurs besoins. catalogue Meta Cares {$jsonSampleData} Liste des Sites Référencés : - PubMed : [https://pubmed.ncbi.nlm.nih.gov/](https://pubmed.ncbi.nlm.nih.gov/) - ScienceDirect : [https://www.sciencedirect.com/](https://www.sciencedirect.com/) --- - Génération d’images DALL·E : Désactivée EOT; $this->conversationHistory[] = [ 'role' => 'system', 'content' => $systemRoleContent ]; if (session_status() == PHP_SESSION_NONE) { session_start(); } if (isset($_SESSION['chat_history'])) { $this->conversationHistory = $_SESSION['chat_history']; } } public function fetchProductsUsingModel(): array { return $products; } private function getCategoryNames(array $categoryIds): array { return $categoryNames; } public function sendMessage(string $message): array { try { $this->conversationHistory[] = [ 'role' => 'user', 'content' => $message ]; $data = [ 'model' => 'gpt-4o', 'messages' => array_map(function ($msg) { return [ 'role' => $msg['role'] === 'bot' ? 'assistant' : $msg['role'], 'content' => $msg['content'] ]; }, $this->conversationHistory) ]; $response = $this->makeApiRequest($data); $arrResult = json_decode($response, true); if (json_last_error() !== JSON_ERROR_NONE) { throw new \Exception('Invalid API response format'); } if (!isset($arrResult['choices']) || !isset($arrResult['choices'][0]['message']['content'])) { throw new \Exception('Unexpected API response structure: ' . $response); } $assistantResponse = $arrResult['choices'][0]['message']['content']; $this->conversationHistory[] = [ 'role' => 'bot', 'content' => $assistantResponse ]; $_SESSION['chat_history'] = $this->conversationHistory; return [ "conversationHistory" => $_SESSION['chat_history'], 'didFetchProducts' => $this->didFetchProducts, 'response' => $assistantResponse, ]; } catch (\Exception $e) { throw new \Exception('ChatBot Error: ' . $e->getMessage()); } } private function makeApiRequest(array $data): string { $ch = curl_init(); curl_setopt_array($ch, [ CURLOPT_URL => $this->endpoint, CURLOPT_POST => true, CURLOPT_POSTFIELDS => json_encode($data), CURLOPT_HTTPHEADER => [ 'Content-Type: application/json', 'Authorization: Bearer ' . $this->authorization, ], CURLOPT_RETURNTRANSFER => true, CURLOPT_SSL_VERIFYPEER => false, CURLOPT_SSL_VERIFYHOST => 0 ]); $response = curl_exec($ch); if (curl_errno($ch)) { $error = curl_error($ch); curl_close($ch); throw new \Exception('API request failed: ' . $error); } curl_close($ch); return $response; } }
好了,本文到此结束,带大家了解了《如何优化大型 JSON 文件以与 ChatGPT API 一起使用?》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- linux scppem怎样进行版本管理

- 下一篇
- 特朗普称计划对中国商品征收25%的关税 外交部回应
查看更多
最新文章
-
- 文章 · php教程 | 40分钟前 |
- PHP尾调用优化怎么实现?
- 263浏览 收藏
-
- 文章 · php教程 | 46分钟前 | 正则表达式 数组 explode 字符串分割 preg_split
- PHP字符串自定义转数组方法:preg_split实例解析
- 444浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- WSL中PHP执行命令stdout捕获失败原因与解决方法
- 303浏览 收藏
-
- 文章 · php教程 | 3小时前 |
- ApacheAlias安全访问外部图片教程
- 210浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- PHP动态SQL与日期遍历技巧解析
- 404浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- PHP DOMDocument与XPath文本节点修改技巧
- 361浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- PHP表单提交后会话数据丢失原因及解决方法
- 289浏览 收藏
-
- 文章 · php教程 | 4小时前 |
- 事务处理如何使用?保障数据一致性技巧
- 102浏览 收藏
-
- 文章 · php教程 | 5小时前 | Curl Http请求 API测试 RESTfulAPI 在线PHP工具
- PHP测试RESTfulAPI步骤与工具推荐
- 388浏览 收藏
-
- 文章 · php教程 | 5小时前 |
- PHP优化慢查询:连接MariaDB技巧分享
- 383浏览 收藏
-
- 文章 · php教程 | 6小时前 |
- PHP连接SQLServer完整教程
- 428浏览 收藏
-
- 文章 · php教程 | 6小时前 |
- PHPMySQLCRUD教程及代码示例
- 471浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 11次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 21次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 10次使用
-
- 酷宣AI
- 酷宣AI是一款专注于高颜值文章快速生成的智能工具。它能根据主题或文字智能排版,实现图文高清整合,并支持一键同步至微信公众号、导出PDF,大幅提升内容创作效率与美观度。
- 6次使用
-
- 花瓣网
- 花瓣网是中国领先的创意灵感与版权素材平台,提供海量正版素材、设计工具和灵感发现引擎,服务设计师、企业用户及创意从业者,助力高效创作。
- 13次使用
查看更多
相关文章
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览