当前位置:AIGC资讯 > AIGC > 正文

通过Whisper模型将YouTube播放列表中的视频转换成高质量文字稿的项目

项目简介

一个通过Whisper模型将YouTube播放列表中的视频转换成高质量文字稿的项目。

这个基于 Python 的工具旨在将 YouTube 视频和播放列表转录为文本。它集成了多种技术,例如用于转录的 Fast-Whisper、用于自然语言处理的 SpaCy 以及用于 GPU 加速的 CUDA,旨在高效处理视频内容。该脚本能够处理单个视频和整个播放列表,输出准确的文字记录和元数据。项目核心内容:

1、YouTube下载:使用pytube下载YouTube视频或播放列表的音频。
2、音频转录:利用faster_whisper.WhisperModel将音频转换成文字。
3、NLP处理:可选地整合SpaCy,用于改进句子分割,提高文字稿的可读性和结构。
4、CUDA加速:实现CUDA支持,用于兼容硬件的处理速度提升。

这个工具适用于内容分析、辅助创建视频字幕和封闭字幕、教育目的以及视频内容的存档和检索。

功能概述

核心组件

YouTube 下载:使用 pytube 从 YouTube 视频或播放列表下载音频。

音频转录:利用 faster_whisper.WhisperModel 将音频转换为文本。该模型是 OpenAI 的 Whisper 的变体,旨在提高速度和准确性。

NLP 处理:可以选择集成 SpaCy 以进行复杂的句子分割,从而增强转录本的可读性和结构。

CUDA 加速:实现对 GPU 利用率的 CUDA 支持,提高兼容硬件的处理速度。

详细工作流程

初始化:

该脚本首先根据 convert_single_video 标志确定是处理单个视频还是播放列表。

它设置必要的目录来存储下载的音频、文字记录和元数据。

环境配置:

将 CUDA Toolkit 路径添加到系统环境以供 GPU 使用。

根据 CPU 核心数配置用于转录的工作线程数量。

视频处理:

对于播放列表中的每个视频或单个视频,脚本都会下载音频。

它确保每个音频文件的唯一命名以避免覆盖。

转录:

音频文件被传递到 WhisperModel 进行转录。

如果可用,该脚本会处理 GPU 加速,否则默认为 CPU。

使用 SpaCy 或基于自定义正则表达式的拆分器将转录结果拆分为句子。

元数据生成:

除了脚本之外,脚本还会生成元数据,包括每个片段的时间戳和置信度分数。

输出:

记录以纯文本、CSV 和 JSON 格式保存,提供原始记录和结构化元数据。

显示/读取:

为了使文字记录更易于阅读,提供了一个 html 文件 transcript_reader.html ,它可以进一步清理并提供“阅读器模式”,您可以在其中选择字体、文本大小、文本宽度和切换深色模式。只需在浏览器中打开此 html 文件,然后粘贴 generated_transcript_combined_texts 文件夹中生成的文件之一的转录文本即可。

实际操作的屏幕截图 将成绩单文本粘贴到成绩单阅读器 HTML 文件中 使用深色模式和 Cambria 字体的阅读器

项目链接

https://github.com/Dicklesworthstone/bulk_transcribe_youtube_videos_from_playlist

更新时间 2023-12-04