Python怎么实现视频自动打码
发表于:2025-11-15 作者:千家信息网编辑
千家信息网最后更新 2025年11月15日,今天小编给大家分享一下Python怎么实现视频自动打码的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一
千家信息网最后更新 2025年11月15日Python怎么实现视频自动打码
今天小编给大家分享一下Python怎么实现视频自动打码的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
准备工作
环境咱们还是使用 Python3.8 和 pycharm2021 即可
实现原理
将视频分为音频和画面;
画面中出现人脸和目标比对,相应人脸进行打码;
处理后的视频添加声音;
模块
手动安装一下 cv2 模块 ,pip install opencv-python 安装
素材工具
我们需要安装一下 ffmpeg 音视频转码工具
代码解析
导入需要使用的模块
import cv2 import face_recognition # 人脸识别库 99.7% cmake dlib face_recognitionimport subprocess
将视频转为音频
def video2mp3(file_name): """ :param file_name: 视频文件路径 :return: """ outfile_name = file_name.split('.')[0] + '.mp3' cmd = 'ffmpeg -i ' + file_name + ' -f mp3 ' + outfile_name print(cmd) subprocess.call(cmd, shell=False)打码
def mask_video(input_video, output_video, mask_path='mask.jpg'): """ :param input_video: 需打码的视频 :param output_video: 打码后的视频 :param mask_path: 打码图片 :return: """ # 读取图片 mask = cv2.imread(mask_path) # 读取视频 cap = cv2.VideoCapture(input_video) # 视频 fps width height v_fps = cap.get(5) v_width = cap.get(3) v_height = cap.get(4) # 设置写入视频参数 格式MP4 # 画面大小 size = (int(v_width), int(v_height)) fourcc = cv2.VideoWriter_fourcc('m', 'p', '4', 'v') # 输出视频 out = cv2.VideoWriter(output_video, fourcc, v_fps, size) # 已知人脸 known_image = face_recognition.load_image_file('tmr.jpg') biden_encoding = face_recognition.face_encodings(known_image)[0] cap = cv2.VideoCapture(input_video) while (cap.isOpened()): ret, frame = cap.read() if ret: # 检测人脸 # 人脸区域 face_locations = face_recognition.face_locations(frame) for (top_right_y, top_right_x, left_bottom_y, left_bottom_x) in face_locations: print((top_right_y, top_right_x, left_bottom_y, left_bottom_x)) unknown_image = frame[top_right_y - 50:left_bottom_y + 50, left_bottom_x - 50:top_right_x + 50] if face_recognition.face_encodings(unknown_image) != []: unknown_encoding = face_recognition.face_encodings(unknown_image)[0] # 对比人脸 results = face_recognition.compare_faces([biden_encoding], unknown_encoding) # [True] # 贴图 if results == [True]: mask = cv2.resize(mask, (top_right_x - left_bottom_x, left_bottom_y - top_right_y)) frame[top_right_y:left_bottom_y, left_bottom_x:top_right_x] = mask out.write(frame) else: break音频添加到画面
def video_add_mp3(file_name, mp3_file): """ :param file_name: 视频画面文件 :param mp3_file: 视频音频文件 :return: """ outfile_name = file_name.split('.')[0] + '-f.mp4' subprocess.call('ffmpeg -i ' + file_name + ' -i ' + mp3_file + ' -strict -2 -f mp4 ' + outfile_name, shell=False)完整代码
import cv2 import face_recognition # 人脸识别库 99.7% cmake dlib face_recognitionimport subprocessdef video2mp3(file_name): outfile_name = file_name.split('.')[0] + '.mp3' cmd = 'ffmpeg -i ' + file_name + ' -f mp3 ' + outfile_name print(cmd) subprocess.call(cmd, shell=False)def mask_video(input_video, output_video, mask_path='mask.jpg'): # 读取图片 mask = cv2.imread(mask_path) # 读取视频 cap = cv2.VideoCapture(input_video) # 视频 fps width height v_fps = cap.get(5) v_width = cap.get(3) v_height = cap.get(4) # 设置写入视频参数 格式MP4 # 画面大小 size = (int(v_width), int(v_height)) fourcc = cv2.VideoWriter_fourcc('m', 'p', '4', 'v') # 输出视频 out = cv2.VideoWriter(output_video, fourcc, v_fps, size) # 已知人脸 known_image = face_recognition.load_image_file('tmr.jpg') biden_encoding = face_recognition.face_encodings(known_image)[0] cap = cv2.VideoCapture(input_video) while (cap.isOpened()): ret, frame = cap.read() if ret: # 检测人脸 # 人脸区域 face_locations = face_recognition.face_locations(frame) for (top_right_y, top_right_x, left_bottom_y, left_bottom_x) in face_locations: print((top_right_y, top_right_x, left_bottom_y, left_bottom_x)) unknown_image = frame[top_right_y - 50:left_bottom_y + 50, left_bottom_x - 50:top_right_x + 50] if face_recognition.face_encodings(unknown_image) != []: unknown_encoding = face_recognition.face_encodings(unknown_image)[0] # 对比人脸 results = face_recognition.compare_faces([biden_encoding], unknown_encoding) # [True] # 贴图 if results == [True]: mask = cv2.resize(mask, (top_right_x - left_bottom_x, left_bottom_y - top_right_y)) frame[top_right_y:left_bottom_y, left_bottom_x:top_right_x] = mask out.write(frame) else: breakdef video_add_mp3(file_name, mp3_file): outfile_name = file_name.split('.')[0] + '-f.mp4' subprocess.call('ffmpeg -i ' + file_name + ' -i ' + mp3_file + ' -strict -2 -f mp4 ' + outfile_name, shell=False)if __name__ == '__main__': # 1. video2mp3('cut.mp4') # 2. mask_video(input_video='cut.mp4',output_video='output.mp4') # 3. video_add_mp3(file_name='output.mp4',mp3_file='cut.mp3')以上就是"Python怎么实现视频自动打码"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
视频
人脸
画面
知识
篇文章
音频
图片
文件
模块
代码
内容
区域
参数
大小
工具
格式
贴图
检测
输出
不同
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
金格签章管理服务器
浪潮服务器改管理口ip
易语言怎么把图片写到数据库
系统软件开发人员工作在
数据库access 容量
搜索框输入后怎么找到数据库
数据库hang住影响
佳诚网络技术
华为服务器视频教程
运城盘古百晋网络技术公司
北碚网络安全信息城
vb操作数据库
辽宁服务器机柜咨询报价
服务器长时间运行关机断电
重庆应用软件开发需要多少钱
山东网络技术专业专升本要考几科
全球贸易数据库gtt
派出所检查督导网络安全
网络安全对生活有哪些影响
开展网络安全反诈宣传
数据库优化代码
centos端口连接数据库
dns服务器上不了网
现数据库中有三个表
sql数据库密码查询
去哪找河南虚拟主机服务器
运营商网络安全
求生之路2服务器图片公告
你的手机已连接到服务器上
线上合同数据库