开源模型应用落地-语音转文本-openai-STT服务-AIGC应用探索(四)

2024-06-03 20:04

本文主要是介绍开源模型应用落地-语音转文本-openai-STT服务-AIGC应用探索(四),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言

    语音转文本技术具有重要价值。它能提高信息记录和处理的效率,使人们可以快速将语音内容转换为可编辑、可存储的文本形式,方便后续查阅和分析。在教育领域,可帮助学生更好地记录课堂重点;在办公场景中,能简化会议记录工作。同时,该技术也为残障人士提供了便利,让他们能更方便地与外界交流。此外,对于媒体行业、客服行业等都有着广泛的应用,极大地提升了工作流程和服务质量。 

    本文将介绍OpenAI付费的语音识别服务。这个服务可以帮助用户将语音转换成文本,为用户提供方便实用的语音转文本服务。


二、术语介绍

2.1. 语音转文本

    也称为语音识别或自动语音识别 (ASR)是一种将语音音频转换为文字的技术。它利用计算机程序和算法来监听语音输入,并将其转换为可读的文字输出。

2.2. Whisper(付费版本)

    Whisper是一个通用语音识别模型。它是在大型多样化音频数据集上训练的,也是一个多任务模型,可以执行多语言语音识别、语音翻译和语言鉴别。

    目前,开源版本的Whisper和通过Openai API提供的版本没有区别。但是,通过Openai API,提供了优化的推理过程,这使得通过API运行Whisper的速度要快于其他方式。

    具体参见:  https://platform.openai.com/docs/models/whisper


三、构建环境

3.1.基础环境

  1.  操作系统:centos7
  2.  Tesla V100-SXM2-32GB  CUDA Version: 12.2

3.2.安装虚拟环境

conda create -n whisper  python=3.10
conda activate whisper
pip install openai

四、技术实现

4.1. 准备测试音频文件

先搞个测试音频:英语诗歌朗诵:Freedom 珍惜自由_Mp3免费下载-在线听力 - 听力课堂

4.2. Openai调用方式

4.2.1.Transcriptions

# -*- coding: utf-8 -*-
import os
from openai import OpenAIos.environ["OPENAI_API_KEY"] = 'sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'    #你的Open AI Keyif __name__ == '__main__':input_path = "C:\\Downloads\\freedom.mp3"client = OpenAI()audio_file = open(input_path, "rb")transcription = client.audio.transcriptions.create(model="whisper-1",file=audio_file)print(transcription.text)

调用结果:

结论:

Openai生成的文本和官方提供的文本有一些差异(我也没有听过测试音频,不敢保证官方提供的文本是否百分百正确,或者模型生成的才是正解,你们来动手实践一下,看看谁更准确呢?),对比如下:

注意:

文件上传目前限制为25 MB,支持以下输入文件类型:mp3、mp4、mpeg、mpga、m4a、wav和webm。

4.2.2.Translations

# -*- coding: utf-8 -*-
import os
from openai import OpenAIos.environ["OPENAI_API_KEY"] = 'sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'    #你的Open AI Keyif __name__ == '__main__':input_path = "C:\\Downloads\\freedom.mp3"client = OpenAI()audio_file = open(input_path, "rb")translation = client.audio.translations.create(model="whisper-1",file=audio_file)print(translation.text)

调用结果:

执行结果与实现方式一一致

4.3. 传统调用方式

# -*- coding: utf-8 -*-
import requestsurl = "https://api.openai.com/v1/audio/transcriptions"
OPENAI_API_KEY = 'sk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'    #你的Open AI Keyif __name__ == '__main__':input_path = "C:\\Downloads\\freedom.mp3"headers = {"Authorization": f"Bearer {OPENAI_API_KEY}"}files = {'file': ('freedom.mp3', open(input_path, 'rb'), 'application/octet-stream')}params = {'model': 'whisper-1'}with open(input_path, 'rb') as file:response = requests.post(url, files={'file': file}, data=params, headers=headers)if response.status_code == 200:print("Audio transcription successful!")print(response.json())else:print("Audio transcription failed.")print(response.text)

调用结果:

执行结果与实现方式一一致

PS:

1. 实现方式三不需要安装openai库,更轻便,通用性更好

2. 切换url(https://api.openai.com/v1/audio/transcriptions)可以实现音频翻译的功能

4.4. CURL调用方式

Transcriptions

curl --request POST \--url https://api.openai.com/v1/audio/transcriptions \--header "Authorization: Bearer $OPENAI_API_KEY" \--header 'Content-Type: multipart/form-data' \--form file=@/path/to/file/audio.mp3 \--form model=whisper-1

Translations

curl --request POST \--url https://api.openai.com/v1/audio/translations \--header "Authorization: Bearer $OPENAI_API_KEY" \--header 'Content-Type: multipart/form-data' \--form file=@/path/to/file/german.mp3 \--form model=whisper-1

五、附带说明

5.1. 方式一的​Transcriptions​和方式二的Translations的区别

  • Transcriptions:将音频转录为音频所使用的任何语言。
  • Translations:将音频翻译并转录成英文。与Transcriptions差异是Translations的输出不是原始输入语言,而是翻译成英文文本。

5.2. 方式三出现“Could not parse multipart form”问题

解决方法:把请求头的"Content-Type": "multipart/form-data" 声明去掉

这篇关于开源模型应用落地-语音转文本-openai-STT服务-AIGC应用探索(四)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027970

相关文章

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

Nginx内置变量应用场景分析

《Nginx内置变量应用场景分析》Nginx内置变量速查表,涵盖请求URI、客户端信息、服务器信息、文件路径、响应与性能等类别,这篇文章给大家介绍Nginx内置变量应用场景分析,感兴趣的朋友跟随小编一... 目录1. Nginx 内置变量速查表2. 核心变量详解与应用场景3. 实际应用举例4. 注意事项Ng

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

Java领域模型示例详解

《Java领域模型示例详解》本文介绍了Java领域模型(POJO/Entity/VO/DTO/BO)的定义、用途和区别,强调了它们在不同场景下的角色和使用场景,文章还通过一个流程示例展示了各模型如何协... 目录Java领域模型(POJO / Entity / VO/ DTO / BO)一、为什么需要领域模

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②