python之图片与视频互转
图片转视频
def image_to_video(image_dir, video_dir, fps):
im_list = [i for i in os.listdir(image_dir) if i.endswith('jpg')]
im_list.sort(key=lambda x: int(x.replace("frame", "").split('.')[0])) # 最好再看看图片顺序对不
# fourcc = cv2.VideoWriter_fourcc(*'XVID') # opencv版本是3
# fourcc = cv2.VideoWriter_fourcc(*'MJPG') # avi
fourcc = cv2.VideoWriter_fourcc(*'mp4v') # mp4
videoWriter = cv2.VideoWriter(video_dir, fourcc, fps, (1920, 1080))
# videoWriter = cv2.VideoWriter(video_dir, fourcc, fps, img_size)
for i in im_list:
im_name = os.path.join(image_dir ,i)
frame = cv2.imdecode(np.fromfile(im_name, dtype=np.uint8), -1)
frame = cv2.resize(frame, (1920, 1080)) #必须设置此步骤,不然文件夹下分辨不一致的图片不会写入视频
videoWriter.write(frame)
videoWriter.release()
print('finish')
视频转图片
def video_to_img(video_path, frame_save_dir, frame_interval=1000):
"""
:param video_path: 视频路径
:param frame_save_dir: 视频帧的存储路径
:param frame_interval: 视频帧的采样间隔
:return:
"""
cap = cv2.VideoCapture(video_path, )
suc = cap.isOpened()
frame_count = 0
while suc:
suc, frame = cap.read() # suc是bool变量,用于判断视频帧是否存在
frame_count += 1
if (suc and frame_count % frame_interval == 0):
save_path = os.path.join(frame_save_dir, "{:04d}.jpg".format(frame_count)) # 格式化命名,不足补零
cv2.imwrite(save_path, frame)
print(frame_count, suc)
cap.release()
图片压缩
def image_compress(path,new_path):
if not os.path.exists(new_path):
os.makedirs(new_path)
# 获取文件夹里面的图片
path_list = [path +os.sep + i for i in os.listdir(path)]
# print(path_list)
# 循环图片路径,依次对图片进行压缩
for _path in path_list:
im = Image.open(_path)
(x, y) = im.size # 读取图片尺寸(像素)
x_1 = 800 # 定义缩小后的标准宽度
y_1 = int(y * x_1 / x) # 计算缩小后的高度
# x_1 = x # 定义缩小后的标准宽度
# y_1 = y # 计算缩小后的高度
out = im.resize((x_1, y_1), Image.ANTIALIAS) # 改变尺寸,保持图片高品质
# 判断图片的通道模式,若图片在RGBA模式下,需先将其转变为RGB模式
if out.mode == 'RGBA':
# 转化为rgb格式
out = out.convert('RGB')
# 最后保存为jpg格式的图片,这里因为图片本身为jpg所以后缀不更改
out.save(f'{new_path}{os.sep}{_path.split(os.sep)[-1]}')
批量复制图片
def batch_copy_file(source_file,out_filepath,copy_num):
if not os.path.exists(out_filepath):
os.makedirs(out_filepath)
if os.path.isdir(source_file):
source_files=[source_file+os.sep+i for i in os.listdir(source_file) ]
elif os.path.isfile(source_file):
source_files=[source_file]
else:
raise Exception("文件夹不存在")
frame_num=1
for _source in source_files:
# source_file_name=_source.split(os.sep)[-1]
# print(source_file_name)
for i in range(copy_num):
# shutil.copyfile(_source,os.path.join(out_filepath,source_file_name.split('.')[0]+'-'+str(i)+'.'+source_file_name.split('.')[-1]))
shutil.copyfile(_source,os.path.join(out_filepath,"frame"+str(frame_num)+'.jpg'))
frame_num+=1
python之图片与视频互转的更多相关文章
- FFmpeg常用命令学习笔记(六)图片与视频互转命令
图片与视频互转命令 1.视频转图片 ffmpeg -i in.mp4 -r 1 -f image2 img-%3d.jpeg -r 1:转换图片帧率为1,也就是1秒转1张.-f image2:将媒体文 ...
- Python OpenCV图片转视频 工具贴(三)
Python OpenCV图片转视频 粘贴即用,注意使用时最好把自己的文件按照数字顺序命名.按照引导输入操作. # 一键傻瓜式引导图片串成视频 # 注意使用前最好把文件命名为数字顺序格式 import ...
- 用python复制图片、视频
图片复制 f_src = open('1.jpg','rb') content = f_src.read() f_copy = open('1-副本.jpg','wb') f_copy.write(c ...
- Python+Opencv实现把图片转为视频
1. 安装Opencv包 在Python命令行输入如下命令(如果你使用的Anaconda,直接进入Anaconda Prompt键入命令即可.如果你不知道Anaconda是什么,可以参考王树义老师的文 ...
- 小白学Python(7)——利用Requests下载网页图片、视频
安装 Requests 如果安装了Requests就已经可用了,否则要安装 Requests,只要在你的CMD中运行这个简单命令即可: pip install requests requests使用 ...
- 做bad apple第二步: python如何将视频变成一帧帧的图片,如何将一帧帧的图片转为视频
直接上代码 """视频转图片""" port cv2def getphoto(video_in, video_save): cap = cv ...
- jQuery 人脸识别插件,支持图片和视频
jQuery Face Detection 是一款人脸检测插件,能够检测到图片,视频和画布中的人脸坐标.它跟踪人脸并输出人脸模型的坐标位置为一个数组.我们相信,面部识别技术能够给我们的 Web 应用带 ...
- Silverlight读取Zip文件中的图片与视频
首先看看Demo的截图: 下面我将一步步展示实现这个Demo的过程,这个需求就是读出Zip文件中的图片与视频. Demo整体架构: 首先我们准备几张图片和视频,然后将其压缩至resource.zip文 ...
- 【转】android如何浏览并选择图片 音频 视频
转自:http://www.cnblogs.com/top5/archive/2012/03/06/2381986.html 这几天 在学习并开发android系统的图片浏览 音频 视频 的浏览 ...
- Android 获取SDCard上图片和视频的缩略图
获取图片缩略图和视频缩略图的方法: Java代码: import java.io.File; import android.app.Activity; import android.graphics. ...
随机推荐
- 很好用的python游戏环境(续):强化学习算法走迷宫游戏环境(导航问题 navigation):分享一个python语言的迷宫游戏环境
相关: 很好用的python游戏环境:强化学习算法走迷宫游戏环境(导航问题 navigation):分享一个python语言的迷宫游戏环境 前文分享了一个python下的maze游戏环境,本文再给出一 ...
- 中国特供版4090D已经开始发售
由于美国政府的限制,NVIDIA公司等美国公司不允许向中国出口4090显卡,但是为了绕过美国政府的限制NVIDIA公司推出了中国特供版的4090D显卡. 4090d显卡和4090显卡区别大吗?可以说其 ...
- 读博期间的宿舍 && 行李打包 —— 大连开发区校区
=============================================
- 为python编译C++模块时一定要注意的事情—————不要在anaconda环境下使用cmake来编译C++扩展模块!!!
平时搞python的人很多都会有安装C++扩展模块的需求,而往往这些C++模块都是使用CMAKE做编译配置的,但是如果你这时候shell环境是使用anaconda的话,那么cmake默认调用的GCC和 ...
- DMS:直接可微的网络搜索方法,最快仅需单卡10分钟 | ICML 2024
Differentiable Model Scaling(DMS)以直接.完全可微的方式对宽度和深度进行建模,是一种高效且多功能的模型缩放方法.与先前的NAS方法相比具有三个优点:1)DMS在搜索方面 ...
- DPDK简介
DPDK简介 DPDK(Data Plane Development Kit)数据平面开发工具包,是一个开源软件项目.DPDK通过维护一系列能够加速多核CPU数据包处理的库,提供数据处理框架.DPDK ...
- parser.add_argument
parser.add_argument 在解析参数时,有个地方很值得注意. --dict-name,会把dict-name解析为变量dict_name.也就是说会把破折号转成下划线.
- 免费在线OCR识别工具TextIn Tools,开启智能学习新时代
传统的学习方式,笔记必须手写摘抄:带字照片只能插入文档:PDF转换要花钱买会员-- 而在线OCR识别工具tools.textin.com,既好用又免费,它不仅仅具有文字和表格识别工具,还包含PDF转文 ...
- JavaScript – Sort
前言 排序是很常见的需求. 虽然看似简单, 但其实暗藏杀机. 一不小心就会搞出 Bug 哦. 这篇就来聊聊 JS 的排序. 参考 原生JS数组sort()排序方法内部原理探究 值的比较 js中的loc ...
- Kubernetes基础(Pod?Label?Namespace?Deployment?Service?)(十二)
上面我们都是在架构层面了解 Kubernetes,但是似乎没有发现关于容器的说明,Kubernetes 作为容器编排引擎,那么他是怎么去对容器进行编排的呢?在 Kubernetes 集群中抽象了很多集 ...