MsEdgeTTS: 简单而强大的微软 Edge 语音合成模块

RayRay
MsEdgeTTS文本到语音Microsoft EdgeAzure Speech ServiceSSMLGithub开源项目

MsEdgeTTS

MsEdgeTTS: 简单而强大的微软 Edge 语音合成模块

在当今数字化时代,语音技术正在迅速发展并广泛应用于各个领域。作为开发者,我们经常需要在应用中集成文本转语音(TTS)功能,以提升用户体验。然而,许多现有的TTS解决方案要么功能有限,要么使用复杂。幸运的是,MsEdgeTTS的出现为开发者提供了一个简单而强大的选择。

MsEdgeTTS 简介

MsEdgeTTS 是一个基于微软 Edge 浏览器的文本转语音 API 的简单 Azure 语音服务模块。它利用了微软 Edge 的"朗读"功能,为开发者提供了一种便捷的方式来实现高质量的语音合成。这个开源项目由 GitHub 用户 Migushthe2nd 创建和维护,目前在 GitHub 上已获得了 265 颗星和 40 次分叉,显示出其受欢迎程度和实用性。

MsEdgeTTS npm version

MsEdgeTTS 的主要特性

  1. 简单易用: MsEdgeTTS 提供了简洁的 API,使得集成和使用变得非常容易。
  2. 支持 SSML: 该模块完全支持语音合成标记语言(SSML),允许开发者对生成的语音进行精细控制。
  3. 多种音频格式: MsEdgeTTS 支持多种音频输出格式,满足不同应用场景的需求。
  4. 流式输出: 支持将生成的音频作为流输出,适用于实时应用。
  5. 文件输出: 可以直接将生成的音频保存为文件,方便后续使用。
  6. 语音参数调整: 允许调整语音的速率、音调和音量,实现个性化的语音效果。
  7. 支持自定义 HTTP Agent: 可以使用自定义的 HTTP Agent,如代理,增强了在不同网络环境下的适应性。

深入了解 MsEdgeTTS

SSML 支持

MsEdgeTTS 对 SSML 的支持主要集中在 speakvoiceprosody 元素类型。以下是默认的 SSML 对象结构:

<speak version="1.0" xmlns="http://www.w3.org/2001/10/synthesis" xmlns:mstts="https://www.w3.org/2001/mstts" xml:lang="${this._voiceLang}"> <voice name="${voiceName}"> <prosody rate="${rate}" pitch="${pitch}" volume="${volume}"> ${input} </prosody> </voice> </speak>

这种结构允许开发者精确控制语音的各个方面,包括语言、声音、速率、音调和音量。

音频格式支持

MsEdgeTTS 支持多种音频输出格式,包括但不限于:

  • WEBM_24KHZ_16BIT_MONO_OPUS
  • AUDIO_24KHZ_48KBITRATE_MONO_MP3
  • AUDIO_24KHZ_96KBITRATE_MONO_MP3

完整的支持格式列表可以在项目的 OUTPUT_FORMAT.ts 文件中找到。

使用 MsEdgeTTS

让我们通过几个实际的例子来看看如何使用 MsEdgeTTS。

1. 流式输出

import {MsEdgeTTS, OUTPUT_FORMAT} from "msedge-tts"; const tts = new MsEdgeTTS(); await tts.setMetadata("en-IE-ConnorNeural", OUTPUT_FORMAT.WEBM_24KHZ_16BIT_MONO_OPUS); const readable = tts.toStream("Hi, how are you?"); readable.on("data", (data) => { console.log("DATA RECEIVED", data); // 处理原始音频文件数据 }); readable.on("close", () => { console.log("STREAM CLOSED"); });

这个例子展示了如何创建一个 MsEdgeTTS 实例,设置元数据(包括语音和输出格式),然后将文本转换为音频流。这种方法特别适合需要实时处理音频的应用场景。

2. 文件输出

import {MsEdgeTTS, OUTPUT_FORMAT} from "msedge-tts"; (async () => { const tts = new MsEdgeTTS(); await tts.setMetadata("en-US-AriaNeural", OUTPUT_FORMAT.WEBM_24KHZ_16BIT_MONO_OPUS); const filePath = await tts.toFile("./example_audio.webm", "Hi, how are you?"); })();

这个例子展示了如何将生成的音频直接保存为文件。这对于需要预先生成音频文件的应用非常有用。

3. 调整语音参数

import {MsEdgeTTS, OUTPUT_FORMAT} from "msedge-tts"; (async () => { const tts = new MsEdgeTTS(); await tts.setMetadata("en-US-AriaNeural", OUTPUT_FORMAT.WEBM_24KHZ_16BIT_MONO_OPUS); const filePath = await tts.toFile("./example_audio.webm", "Hi, how are you?", {rate: 0.5, pitch: "+200Hz"}); })();

在这个例子中,我们展示了如何调整语音的速率和音调。这允许开发者创建更加个性化和富有表现力的语音输出。

4. 使用自定义 HTTP Agent

import {SocksProxyAgent} from 'socks-proxy-agent'; (async () => { const agent = new SocksProxyAgent("socks://your-name%40gmail.com:abcdef12345124@br41.nordvpn.com") const tts = new MsEdgeTTS(agent); await tts.setMetadata("en-US-AriaNeural", OUTPUT_FORMAT.WEBM_24KHZ_16BIT_MONO_OPUS); const filePath = await tts.toFile("./example_audio.webm", "Hi, how are you?"); })();

这个例子展示了如何使用自定义的 HTTP Agent,在这里是一个 SOCKS 代理。这对于需要通过特定网络或代理访问 API 的场景非常有用。

MsEdgeTTS 的优势

  1. 免费使用: 作为一个开源项目,MsEdgeTTS 可以免费使用,这对于预算有限的开发者和小型项目来说是一个巨大的优势。
  2. 高质量语音: 利用微软 Edge 的语音技术,MsEdgeTTS 能够生成高质量的语音输出。
  3. 灵活性: 支持多种音频格式和参数调整,使得它能够适应各种不同的应用需求。
  4. 易于集成: 简单的 API 设计使得 MsEdgeTTS 可以轻松集成到各种 JavaScript 和 TypeScript 项目中。
  5. 活跃的社区: GitHub 上的活跃度表明,这个项目有一个积极参与的社区,这意味着持续的改进和支持。

结语

MsEdgeTTS 为开发者提供了一个强大而简单的工具,用于在他们的应用中集成高质量的文本转语音功能。无论是构建辅助技术、创建有声书应用,还是开发需要语音输出的教育软件,MsEdgeTTS 都是一个值得考虑的选择。

随着语音技术在各个领域的应用日益广泛,像 MsEdgeTTS 这样的工具将在塑造更加包容和交互式的数字体验中发挥重要作用。我们期待看到开发者如何利用这个工具创造出创新的应用和解决方案。

如果你对 MsEdgeTTS 感兴趣,可以访问其 GitHub 仓库 了解更多信息,或查阅 API 文档 以获取详细的使用指南。无论你是经验丰富的开发者还是刚刚开始探索语音技术的新手,MsEdgeTTS 都为你提供了一个绝佳的起点。

MsEdgeTTS GitHub Stars

让我们一起探索 MsEdgeTTS 的潜力,为用户创造更加丰富和互动的语音体验! 🎙️💻🚀

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多