使用python生成文字视频

666 阅读3分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第7天,点击查看活动详情

网上有很多那种只有文字的视频,基本是都是一段文字,加上背景音乐,定时显示几个词语;好几次刷到这些视频,想到应该可以使用python生成;

基本原理

1、读取文本获取分词或分段列表
2、通过分词列表生成文字素材视频列表
3、通过文字素材生成视频
4、视频合并音频

用到的库:

分词库 jieba 视频处理 moivepy

  • jieba是一款优秀的 Python 第三方中文分词库,支持三种分词模式:

精确模式:试图将语句最精确的切分,不存在冗余数据,适合做文本分析 全模式:将语句中所有可能是词的词语都切分出来,速度很快,但是存在冗余数据 搜索引擎模式:在精确模式的基础上,对长词再次进行切分

  • jieba的安装方式比较简单,使用Ctrl+R打开命令行窗口,执行命令:
  • pip install jieba 等待安装成功(需要联网) 在这里插入图片描述 验证是否安装成功; 打开python交互窗口,引入jieba

import jieba 在这里插入图片描述

  • MoviePy是一个用于视频编辑的python模块,你可以用它实现一些视频剪辑,视频拼接等基本操作,还可以实现视频合成;

  • 安装moviepy: 使用pip方式安装最简单,推荐使用;打开命令行窗口,执行命令:

pip install moviepy 运行以上代码,也会安装所有movicepy依赖的库;

  • MoviePy 依赖的python库有 Numpy, imageio, Decorator, 和 tqdm这些都会在安装MoviePy的时候自动安装.

编码实现:

  1. 实现分词功能函数 导入jieba库:

    import jieba

    传入文本文件地址,读取文本内容 使用jieba.lcut()方法就行分词,获取分词列表 也可以按行分词,不是jieba库; 返回分词列表,给调用者

import jieba
def getSplitWord(filepath,word_split=True):
    '''读取文本文件,获取分词,或者分行'''
    str_text = '没有文本'
    with open(filepath,'r',encoding='utf-8') as f:
        str_text = f.read()

    if word_split:
        seg_list = jieba.lcut(str_text)
        punct = set(''':!),.:;?]}''')
        word_list = list(filter(lambda x: x not in punct, seg_list))
    else:
        word_list = str_text.split('\n')
        word_list = [x for x in word_list if len(x)>0] #去除空白行
   
    return word_list
  1. 根据分词列表生成文字素材

    主要用到movirpy中的TextClip

    from moviepy.editor import TextClip
    

    为防止中文乱码,可以使用以下代码打印出支持的字体列表

    print(TextClip.list('font'))

    具体代码:

    def genTextClip(word_list,width=360,height=640):
    '''生成文字视频素材'''
    clips = []
    text_start = 0
    for word in word_list:
        #print(str(text_start))
        text_clip = TextClip(
            word,
            fontsize=width // 6,
            color='white',
            size=(width, height),
            method='caption',
            font=r"SimHei")\
            .set_start(text_start)\
            .set_end(text_start + 0.8)
        text_clip = text_clip.set_pos('center')
        clips.append(text_clip)
        text_start = text_start + 0.8
    return clips
    

    生成指定分辨率的文字素材列表,以便后续合成使用;

  2. 合成文字素材(添加音频):

    具体参考注释:

    from moviepy.editor import TextClip,AudioFileClip,CompositeVideoClip
    # 合成视频方法,参数素材列表,音频,输出地址
    def compileVideo(clips,music,output):
    #合并文字素材
    final_clip = CompositeVideoClip(clips)
    #加载音频素材
    audio_clip = AudioFileClip(music)
    #视频合并音频
    final_video = final_clip.set_audio(audio_clip)
    #输出完整视频
    final_video.write_videofile(
        output,
        fps=30,
        codec='mpeg4',
        preset='ultrafast',
        audio_codec="libmp3lame",
        threads=4)
    
  3. 执行调用,传递参数,生成 视频 在这里插入图片描述