携手创作,共同成长!这是我参与「掘金日新计划 · 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的时候自动安装.
编码实现:
-
实现分词功能函数 导入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
-
根据分词列表生成文字素材
主要用到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生成指定分辨率的文字素材列表,以便后续合成使用;
-
合成文字素材(添加音频):
具体参考注释:
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) -
执行调用,传递参数,生成 视频