火影忍者做网站的图片网站数据统计
前言
最近发现了一个bug,百度网盘语音转文字是收费的,但是视频导出音频文稿是不收费的
那把音频文件变成视频文件,然后让他识别出文档就可以导出了
因此我准备
准备用Python将一段画面和音频做成一个视频,其中使用moviepy合并的时候报了很多错误,记录一下解决的方法
解决
问题1
from backports import tarfile
ImportError: cannot import name 'tarfile' from 'backports' (C:\ProgramData\anaconda3\Lib\site-packages\backports\__init__.py)
解决1
pip install backports.tarfile
问题2
ModuleNotFoundError: No module named ‘moviepy.editor‘
解决2
去掉.editor
from moviepy import AudioFileClip, ColorClip
最后代码如下
用于将一段mp3文件生成为一个mp4文件
from moviepy import AudioFileClip, ColorClip
import osdef audio_to_video(input_mp3):audio = AudioFileClip(input_mp3)# 正确创建ColorClip(移除fps参数)video = ColorClip(size=(100, 100),color=(0, 0, 0),duration=audio.duration # 仅保留必要参数)# 通过fps设置帧率video = video.with_fps(24)# 合并音频和视频final_clip = video.with_audio(audio)output_mp4 = os.path.splitext(input_mp3)[0] + ".mp4"final_clip.write_videofile(output_mp4,fps=24, # 再次确认导出参数codec="libx264",audio_codec="aac")
# 调用示例
audio_to_video(r"C:\music\喜马拉雅\百家讲坛.mp3")
然后将mp3变成的mp4文件拖到百度网盘,就能立刻生成语音转文字文档导出就行了
升级版
使用线程池,从指定目录中,批量转mp4
#导入多线程模块
from concurrent.futures import ThreadPoolExecutor, as_completed
import threading
import makeMp3_4#自定义的功能就是上面的mp3转mp4函数
import getAllPath#自定义的,就是从一个目录中读取所有mp3结尾的文件路径列表,就不写了
#定义执行函数,每个执行的线程说明自己来过即可
def count_task(tid):threading_name=threading.current_thread().nameprint(f"任务{tid}开始在线程{threading_name}上执行")makeMp3_4.audio_to_video(tid)return f"任务{tid}完成"
allPath=getAllPath.getAllMp3Path()
#创建线程池
with ThreadPoolExecutor(max_workers=100) as executor:# 挨个提交任务到线程池futures=[executor.submit(count_task,i) for i in allPath]#as_completed加载任务队列,一旦某个任务完成,就开始返回执行结果for future in as_completed(futures):result=future.result()print(f"{result}")
print("所有任务完成")