首页 > 文章列表 > 使用OpenAI API在JavaScript中创建文本到语音AI代理

使用OpenAI API在JavaScript中创建文本到语音AI代理

389 2025-02-15

使用OpenAI API在JavaScript中创建文本到语音AI代理

简介

想要用AI将文本转换成语音?OpenAI的文本转语音(TTS)API让开发者能够轻松生成高质量的语音。本文将指导您使用OpenAI API在JavaScript中创建一个简单的AI驱动TTS代理,最终实现文本到语音的播放功能。

前提条件

开始之前,请确保您已安装Node.js(下载地址:此处)并拥有OpenAI API密钥(获取地址:[此处](此处替换为OpenAI API密钥获取链接)),并具备基本的JavaScript知识。

步骤1:安装依赖项

我们将使用axios与OpenAI API交互,以及play-sound播放生成的音频。

npm install axios play-sound

步骤2:编写TTS函数

我们将创建一个函数,实现以下功能:

  1. 向OpenAI的TTS API发送请求;
  2. 保存生成的音频文件;
  3. 播放音频文件。
const axios = require('axios');
const player = require('play-sound')();
const fs = require('fs');

const openai_api_key = 'your-api-key'; // 请替换为您的API密钥

async function textToSpeech(text) {
    try {
        const response = await axios.post(
            'https://api.openai.com/v1/audio/speech',
            {
                model: 'tts-1',
                input: text,
                voice: 'alloy',
            },
            {
                headers: {
                    'Authorization': `Bearer ${openai_api_key}`,
                    'Content-Type': 'application/json',
                },
                responseType: 'arraybuffer',
            }
        );

        const filePath = 'output.mp3';
        fs.writeFileSync(filePath, response.data);
        console.log('正在播放音频...');
        player.play(filePath);
    } catch (error) {
        console.error('错误:', error.response ? error.response.data : error.message);
    }
}

textToSpeech("你好,这是一个AI生成的语音!");

步骤3:运行脚本

将代码保存为tts.js文件,然后运行:

node tts.js

定制

  • 更改语音: OpenAI提供多种语音,例如alloy、echo、fable等,您可以根据需要修改voice参数。
  • 集成到Web应用程序: 您可以通过后端调用API,在前端React/Next.js项目中使用此功能。

结论

只需几行JavaScript代码,我们就成功构建了一个功能强大的AI驱动文本转语音代理。无论是用于辅助功能、自动化还是娱乐,AI驱动的语音合成都具有变革意义。快来尝试一下,用逼真的AI语音增强您的项目吧!