• 剪映+json解析将视频中的声音转换成文本


    前言

    有时候我们想将一段视频中的音频转换成文本,最简单最笨的方法就是通过人耳去听,然后通过打字打出来。但这种方法无疑是十分费劲的。机智的小伙伴肯定都知道我们可以借助语音识别工具来做这件事,但是比较现实的一点就是,很多识别软件不是要收费,就是识别准确率比较低。那么我们有什么办法可以既不花钱又准确的将视频中的音频转换成文本呢?

    解决方法

    有剪辑经验的小伙伴一定知道,剪映这款软件的字幕识别功能,其背后有字节跳动的语音识别技术支撑,对普通话的识别准确率是杠杠的。但是有一点是,他识别的字幕是分段的,要将它们一条条复制出来组成完整的文本,其工作量也不少。
    在这里插入图片描述
    那么,下面介绍一个简单的办法:

    具体操作步骤

    • 1.下载windows版本的剪映
    • 2.导入视频
    • 3.识别字幕(导入视频后,点击文本->智能字幕->开始识别即可)
      在这里插入图片描述
    • 4.等待一段时间后(时间长短与视频文件大小有关),就会自动生成字幕了。
    • 5.生成字幕后,关闭剪映,会自动保存为草稿。此时再打开剪映,右上角会出现草稿参数的方框,在方框中我们可以找到草稿保存的路径。
      在这里插入图片描述
    • 6.在windows资源管理器中打开保存位置,可以看到如下文件。
      在这里插入图片描述
    • 7.根据英文名称不难找出,draft_content.json 中就是我们草稿内容,刚刚生成的字幕文本也保存在这个json文件中。
    • 8.既然是json文件,下一步自然就是json解析了,我们将字幕内容从这个文件中提取出来即可。
    • 9.分析json文件,找出要解析的字段, 简化后的json结构如下:
    {"materials":{"texts":[{"content":"<font id=\"\" path=\"D:/Program Files/JianyingPro/3.0.5.8542/Resources/Font/SystemFont/zh-hans.ttf\"><color=(1.000000, 1.000000, 1.000000, 1.000000)><size=5.000000>同学们好</size></color></font>"}]}}
    
    • 1

    而我们需要的字幕内容,被三个xml元素标签包裹。
    ,

    • 10.我们先通过json解析获取到content字段的内容,然后通过字符串处理的方法剔除xml标签,获取最终文本字幕内容。
      如下是我写的一个简单的python脚本,可以方便快捷的处理剪映这个包含字幕的json文件:
    import json
    
    if __name__ == '__main__':
        with open("draft_content.json", "r", encoding='utf-8') as f:
            json_str = f.read()
            json_content = json.loads(json_str)
            texts_data = json_content["materials"]["texts"]
            for text_data in texts_data:
                content = text_data["content"]
                content = content[:-22]
                result = content.split("><size=")[1].split(">")[1]
                print(result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 11.直接将脚本与json文件放置在同一目录下,执行python脚本即可得到需要的字幕内容。
      到

    我们还可以通过重定向符号,直接将输出的内容生成文件

    python3 parse_jianyin.py >> output.txt
    
    • 1

    在这里插入图片描述

  • 相关阅读:
    线上服务器老是卡,该如何优化?
    ClickHouse(03)ClickHouse怎么安装和部署
    安捷伦数字万用表软件NS-Multimeter,实时数据采集数据自动保存
    微信推送平台-测试号定制推送
    linux上交叉编译qt库
    postman怎么进行参数化?
    ipv6地址概述——深入讲解ipv6地址
    新概念英语(第二册)复习——Lesson 6 - Lesson10
    Windows11 安装配置 JDK 和 Maven
    dos batch动态设置数组
  • 原文地址:https://blog.csdn.net/fangye945a/article/details/125608589