0

0

从OpenAI API响应中高效提取生成文本

聖光之護

聖光之護

发布时间:2025-12-01 12:31:27

|

354人浏览过

|

来源于php中文网

原创

从openai api响应中高效提取生成文本

本文旨在指导开发者如何正确解析OpenAI API返回的JSON格式响应,并从中提取所需的生成文本内容。通过详细的步骤和代码示例,我们将展示如何使用`JSON.parse()`方法处理API响应,并精确访问`choices[0].text`属性以获取核心文本输出,同时探讨处理多条生成结果的方法及相关注意事项。

在与OpenAI API进行交互时,无论是使用text-davinci-002还是其他模型,API的响应通常都是一个结构化的JSON对象。理解并正确解析这个JSON结构是高效利用API生成内容的关键。直接对原始字符串进行截取或正则匹配来提取文本是一种不推荐且容易出错的方法,因为它忽略了JSON作为数据交换格式的内在结构。

理解OpenAI API响应结构

OpenAI API的成功响应通常包含一个JSON对象,其核心生成文本位于choices数组的第一个元素的text属性中。以下是一个典型的API响应示例:

{
  "id": "cmpl-61dshxu43ecbrqir187yilz9mdhsj",
  "object": "text_completion",
  "created": 1665749707,
  "model": "text-davinci-002",
  "choices": [{
    "text": "?\n\nthere is no simple answer to these questions. each person's individual experiences and perspectives will shape their understanding of who they are and what life is. in general, however, people often think of themselves as unique individuals with specific talents, interests, and goals. they may also think of life as a journey full of challenges and opportunities for growth.",
    "index": 0,
    "logprobs": null,
    "finish_reason": "stop"
  }],
  "usage": {
    "prompt_tokens": 7,
    "completion_tokens": 71,
    "total_tokens": 78
  }
}

从上述结构可以看出,我们感兴趣的生成文本位于choices数组内部,具体路径是choices[0].text。

正确提取生成文本的方法

要从OpenAI API的JSON响应中提取文本,正确的步骤是先将原始响应字符串解析为JavaScript对象,然后通过属性访问来获取所需内容。

1. JSON解析

当XMLHttpRequest(或fetch等其他HTTP客户端)接收到API响应时,xhr.responseText属性会包含一个JSON格式的字符串。我们需要使用JSON.parse()方法将其转换为一个可操作的JavaScript对象。

Type Studio
Type Studio

一个视频编辑器,提供自动转录、自动生成字幕、视频翻译等功能

下载
xhr.onreadystatechange = function() {
  if (xhr.readyState === 4) { // 确保请求已完成
    if (xhr.status === 200) { // 检查HTTP状态码是否为成功
      var response = JSON.parse(xhr.responseText);
      // 后续操作
    } else {
      console.error("API请求失败,状态码: " + xhr.status);
      console.error("错误信息: " + xhr.responseText);
    }
  }
};

2. 访问生成文本

一旦响应字符串被解析为JavaScript对象response,我们就可以通过链式属性访问来获取生成文本:

let generatedText = response.choices[0].text;
console.log(generatedText);

这段代码会获取choices数组中的第一个元素(索引为0),然后访问该元素的text属性。

处理多个生成结果(Choices)

OpenAI API允许您通过在请求中设置n参数来生成多个不同的完成结果。在这种情况下,choices数组将包含多个元素。如果您需要处理所有这些结果,可以遍历choices数组:

xhr.onreadystatechange = function() {
  if (xhr.readyState === 4 && xhr.status === 200) {
    var response = JSON.parse(xhr.responseText);
    if (response.choices && response.choices.length > 0) {
      response.choices.forEach((choice, index) => {
        console.log(`Choice ${index + 1}:`);
        console.log(choice.text);
        // 可以在这里对每个生成的文本进行进一步处理
      });
    } else {
      console.log("未找到任何生成文本。");
    }
  } else if (xhr.readyState === 4) {
    console.error("API请求失败,状态码: " + xhr.status);
    console.error("错误信息: " + xhr.responseText);
  }
};

完整示例代码

结合上述方法,以下是修正后的完整JavaScript代码示例,用于调用OpenAI API并正确提取生成文本:

let open_ai_response_text; // 用于存储最终提取的文本

async function openai_test() {
  var prompt_text = "who am i?";
  var prompt_text2 = "what is life?"; // 建议将两个问题合并为一个更清晰的prompt
  var url = "https://api.openai.com/v1/engines/text-davinci-002/completions";

  var xhr = new XMLHttpRequest();
  xhr.open("POST", url);
  xhr.setRequestHeader("Content-Type", "application/json");
  // 请替换为您的实际API密钥
  xhr.setRequestHeader("Authorization", "Bearer sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"); 

  xhr.onreadystatechange = function() {
    if (xhr.readyState === 4) {
      if (xhr.status === 200) {
        try {
          var response = JSON.parse(xhr.responseText);
          // 检查 choices 数组是否存在且不为空
          if (response.choices && response.choices.length > 0) {
            open_ai_response_text = response.choices[0].text;
            console.log("提取到的OpenAI响应文本:");
            console.log(open_ai_response_text);

            // 示例:对提取的文本进行处理(如首字母大写,其他字符小写)
            // 注意:API返回的文本可能包含换行符,需要根据实际需求处理
            // let processedText = open_ai_response_text.trim(); // 移除首尾空白符
            // if (processedText.length > 0) {
            //   processedText = processedText[0].toUpperCase() + processedText.slice(1).toLowerCase();
            // }
            // console.log("处理后的文本:");
            // console.log(processedText);

          } else {
            console.warn("OpenAI API响应中未找到生成文本。");
          }
        } catch (e) {
          console.error("解析JSON响应失败:", e);
          console.error("原始响应文本:", xhr.responseText);
        }
      } else {
        console.error("OpenAI API请求失败,HTTP状态码:", xhr.status);
        console.error("错误详情:", xhr.responseText);
      }
    }
  };

  var data = JSON.stringify({ // 使用JSON.stringify将JavaScript对象转换为JSON字符串
    "prompt": prompt_text + " " + prompt_text2, // 合并prompt
    "temperature": 0.7,
    "max_tokens": 256,
    "top_p": 1,
    "frequency_penalty": 0.75,
    "presence_penalty": 0
  });

  xhr.send(data);
}

// 调用函数以启动API请求
openai_test();

注意事项

  1. API Key 安全: 您的API密钥(sk-xxxxxxxx)是敏感信息,不应直接暴露在客户端代码中。在生产环境中,应通过后端服务器代理API请求,或使用环境变量安全地管理密钥。
  2. 错误处理: 务必检查xhr.status以确保HTTP请求成功(通常是200)。同时,使用try-catch块来处理JSON.parse()可能因响应格式不正确而抛出的错误。
  3. 响应内容检查: 在访问response.choices[0].text之前,最好检查response对象、response.choices数组以及其长度,以避免在API未返回预期结构时出现运行时错误。
  4. 文本后处理: OpenAI返回的text内容可能包含前导或尾随的换行符(\n)或其他空白字符。根据您的应用需求,可能需要使用trim()、replace()等字符串方法进行清理和格式化。
  5. prompt构建: 在原始问题中,prompt_text + prompt_text2可能会导致两个问题之间没有空格,影响模型理解。建议在合并时添加适当的连接符,如prompt_text + " " + prompt_text2。

总结

正确地从OpenAI API响应中提取生成文本,关键在于理解API返回的是JSON格式数据,并利用JSON.parse()将其转换为可操作的JavaScript对象。随后,通过访问response.choices[0].text即可轻松获取核心生成内容。对于需要处理多个生成结果的场景,遍历choices数组是标准做法。遵循这些指导原则,并结合健壮的错误处理机制,将确保您的应用程序能够稳定、高效地与OpenAI API进行交互。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

554

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

731

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

991

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

657

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

551

2023.09.20

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.7万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号