新闻中心
真快!几分钟就把视频语音识别为文本了,不到10行代码
☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

大家好,我是风筝
两年前,将音视频文件转换为文字内容的需求难以实现,但是如今只需几分钟便可轻松解决。
据说一些公司为了获取训练数据,已经对抖音、快手等短视频平台上的视频进行了全面爬取,然后将视频中的音频提取出来转换成文本形式,用作大数据模型的训练语料。
如果您需要将视频或音频文件转换为文字,可以尝试今天提供的这个开源解决方案。例如,可以搜索*节目的对话出现的具体时间点。
话不多说,进入正题。
Whisper
这个方案就是 OpenAI 开源的 Whisper,当然是用 Python 写的了,只需要简单安装几个包,然后几行代码一写,稍等片刻(根据你的机器性能和音视频长度不一),最终的文本内容就出来了,就是这么简单。
GitHub 仓库地址:https://github.com/openai/whisper
Fast-Whisper
尽管已经相当简化,但对于程序员而言仍不够精简。毕竟,程序员们往往偏爱简洁高效。虽然安装和调用Whisper已经相对容易,但仍需要单独安装PyTorch、ffmpeg,甚至Rust。
因此,Fast-Whisper应运而生,它比Whisper更快速、更简洁。Fast-Whisper并非仅仅是对Whisper进行简单封装,而是通过采用CTranslate2重新构建了OpenAI的Whisper模型。CTranslate2是Transformer模型的一种高效推理引擎。
总结一下,也就是比 Whisper 更快,官方的说法是比 Whisper 快了 4-8 倍。不仅能支持 GPU ,还能支持 CPU,连我这台破 Mac 也能用。
刺鸟创客
一款专业高效稳定的AI内容创作平台
110
查看详情
GitHub 仓库地址:https://github.com/SYSTRAN/faster-whisper
使用起来就两步。
- 安装依赖包
pip install faster-whisper
- 写代码,
from faster_whisper import WhisperModelmodel_size = "large-v3"# Run on GPU with FP16model = WhisperModel(model_size, device="cuda", compute_type="float16")# or run on GPU with INT8# model = WhisperModel(model_size, device="cuda", compute_type="int8_float16")# or run on CPU with INT8# model = WhisperModel(model_size, device="cpu", compute_type="int8")segments, info = model.transcribe("audio.mp3", beam_size=5)print("Detected language '%s' with probability %f" % (info.language, info.language_probability))for segment in segments:print("[%.2fs -> %.2fs] %s" % (segment.start, segment.end, segment.text))
没错,就是这么简单。
能做什么呢
正好有个朋友想做短视频,发一些鸡汤文学的视频,鸡汤就来自于一些名家访谈的视频。但是,他又不想把完整的视频看一遍,就想用最快的方式把文本内容弄下来,然后读文字,因为读文字要比看一篇视频快的多,而且还可以搜索。
我就说,连完整的看一篇视频的虔诚之心都没有,能经营好账号吗。
于是我给他做了一个,就是用的 Fast-Whisper。
客户端
客户端用 Swift ,只支持 Mac 端。
- 选则一个视频;
- 然后点击「提取文本」,这时会调用 Python 接口,需要等待一段时间;
- 加载解析出的文本以及出现的开始、截止时间;
- 选了一个开始时间和一个结束事件;
- 点击「导出」按钮,视频片段就导出了;
,时长00:10
服务端
服务端当然就是 Python ,然后用 Flask 包装一下,对外放开接口。
from flask import Flask, request, jsonifyfrom faster_whisper import WhisperModelapp = Flask(__name__)model_size = "large-v2"model = WhisperModel(model_size, device="cpu", compute_type="int8")@app.route('/transcribe', methods=['POST'])def transcribe():# Get the file path from the requestfile_path = request.json.get('filePath')# Transcribe the filesegments, info = model.transcribe(file_path, beam_size=5, initial_prompt="简体")segments_copy = []with open('segments.txt', 'w') as file:for segment in segments:line = "%.2fs|%.2fs|[%.2fs -> %.2fs]|%s" % (segment.start, segment.end, segment.start, segment.end, segment.text)segments_copy.append(line)file.write(line + '\n')# Prepare the responseresponse_data = {"language": info.language,"language_probability": info.language_probability,"segments": []}for segment in segments_copy:response_data["segments"].append(segment)return jsonify(response_data)if __name__ == '__main__':app.run(debug=False)
以上就是真快!几分钟就把视频语音识别为文本了,不到10行代码的详细内容,更多请关注其它相关文章!
# 语音识别
# 毒蛇啤酒营销推广公司
# 全网推广营销网站
# 技术推广思维营销策划
# SEO人才落户政策
# 开源
# 音视频
# 这么简单
# 转换为
# 真快
# 有什么
# 就把
# 多线程
# 几分钟
# type
# udio
# 抖音
# rust
# pytorch
# 推广网站便宜吗知乎
# 国内网络营销推广多少钱
# 长乐厦门网站建设哪家好
# 国内推广论坛有哪些网站
# 网站建设推广销售
# 深圳抖音营销推广收费
相关栏目:
【
行业资讯67740 】
【
技术百科0 】
【
网络运营39195 】
相关推荐:
ai如何重复使用上一命令
夸克内测有什么好处
angluar如何命令删除dist
汽车中控导航机power线是什么意思
春运抢票准备什么东西
春运抢票如何快速抢到票
关系型数据库和非关系型数据库有哪些
苹果手机16有哪些功能
为什么夸克网盘下载不了
360n7lite怎么设置动态壁纸
固态硬盘如何查看盘符
如何ping测试命令
nosql数据库的应用场景有哪些
春运抢票可以抢几次啊
命令行如何打开文件
安全的ao3镜像网站链接入口
typescript入门要多久
电动车power灯亮是什么意思
市盈率tt的扣非是什么意思
j*a怎么存放数组中
折叠手机屏易坏吗为什么
单片机怎么加死循环
单片机怎么连接电路图
j*a怎么清除数组
哪些框架支持typescript
单片机软件keil怎么运行
power在坐标轴中是什么意思
充电器上的power是什么意思
折叠屏手机为什么没火
春运抢票多久可以买到票
广东春运抢票怎么抢不到
gs是什么意思
typescript有什么作用
东芝固态硬盘如何保修
固态硬盘如何装入机箱
红米手机怎么设置变成5G手机
苹果16如何预购
如何使用程序编译 执行的命令
typescript属性只读如何修改
j*a怎么用json数组
如何在命令行写j*a程序
win10如何打开dos命令窗口大小
苹果手机16系统有哪些
苹果16系统有哪些问题
宝马x5仪表盘上边有power是什么意思
内在市盈率是什么意思
得物怎样不扣手续费 如何通过得物不支付手续费
iPhone无法打开YouTube原因分析与解决方案
hive中datediff函数怎么用 Hive中DATEDIFF函数的使用指南
命令不执行如何处理


2024-02-27
浏览次数:次
返回列表
NT8# model = WhisperModel(model_size, device="cpu", compute_type="int8")segments, info = model.transcribe("audio.mp3", beam_size=5)print("Detected language '%s' with probability %f" % (info.language, info.language_probability))for segment in segments:print("[%.2fs -> %.2fs] %s" % (segment.start, segment.end, segment.text))