简介
想要用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函数
我们将创建一个函数,实现以下功能:
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
定制
voice
参数。结论
只需几行JavaScript代码,我们就成功构建了一个功能强大的AI驱动文本转语音代理。无论是用于辅助功能、自动化还是娱乐,AI驱动的语音合成都具有变革意义。快来尝试一下,用逼真的AI语音增强您的项目吧!