图片转视频

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之图片与视频互转的更多相关文章

  1. FFmpeg常用命令学习笔记(六)图片与视频互转命令

    图片与视频互转命令 1.视频转图片 ffmpeg -i in.mp4 -r 1 -f image2 img-%3d.jpeg -r 1:转换图片帧率为1,也就是1秒转1张.-f image2:将媒体文 ...

  2. Python OpenCV图片转视频 工具贴(三)

    Python OpenCV图片转视频 粘贴即用,注意使用时最好把自己的文件按照数字顺序命名.按照引导输入操作. # 一键傻瓜式引导图片串成视频 # 注意使用前最好把文件命名为数字顺序格式 import ...

  3. 用python复制图片、视频

    图片复制 f_src = open('1.jpg','rb') content = f_src.read() f_copy = open('1-副本.jpg','wb') f_copy.write(c ...

  4. Python+Opencv实现把图片转为视频

    1. 安装Opencv包 在Python命令行输入如下命令(如果你使用的Anaconda,直接进入Anaconda Prompt键入命令即可.如果你不知道Anaconda是什么,可以参考王树义老师的文 ...

  5. 小白学Python(7)——利用Requests下载网页图片、视频

    安装 Requests 如果安装了Requests就已经可用了,否则要安装 Requests,只要在你的CMD中运行这个简单命令即可: pip install requests requests使用 ...

  6. 做bad apple第二步: python如何将视频变成一帧帧的图片,如何将一帧帧的图片转为视频

    直接上代码 """视频转图片""" port cv2def getphoto(video_in, video_save): cap = cv ...

  7. jQuery 人脸识别插件,支持图片和视频

    jQuery Face Detection 是一款人脸检测插件,能够检测到图片,视频和画布中的人脸坐标.它跟踪人脸并输出人脸模型的坐标位置为一个数组.我们相信,面部识别技术能够给我们的 Web 应用带 ...

  8. Silverlight读取Zip文件中的图片与视频

    首先看看Demo的截图: 下面我将一步步展示实现这个Demo的过程,这个需求就是读出Zip文件中的图片与视频. Demo整体架构: 首先我们准备几张图片和视频,然后将其压缩至resource.zip文 ...

  9. 【转】android如何浏览并选择图片 音频 视频

    转自:http://www.cnblogs.com/top5/archive/2012/03/06/2381986.html   这几天 在学习并开发android系统的图片浏览 音频 视频 的浏览 ...

  10. Android 获取SDCard上图片和视频的缩略图

    获取图片缩略图和视频缩略图的方法: Java代码: import java.io.File; import android.app.Activity; import android.graphics. ...

随机推荐

  1. 阿里2021年春季实习笔试题(最后一道大题)(2020 China Collegiate Programming Contest, Weihai Site) (C. Rencontre codeforces.com/gym/102798)

    实验室的慕师弟phd马上要毕业了,正准备先找个实习,投了阿里2021年春季实习的招聘,遇到最后一道编程大题没有思路事后找到了该题的最原始出处,即 2020 China Collegiate Progr ...

  2. 【转载】 解决VSCode运行或调试python文件无反应的问题

    ---------------- 版权声明:本文为CSDN博主「姜行者」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明.原文链接:https://blog.csdn. ...

  3. GAN总结

    GAN总结 本篇文章主要是根据GitHub上的GAN代码库[PyTorch-GAN]进行GAN的复习和回顾,对于之前GAN的各种结构的一种简要的概括. Code 关于评价GAN模型的标准 Incept ...

  4. SPI协议,MCP2515裸机驱动详解

    SPI概述 Serial Peripheral interface 通用串行外围设备接口 是Motorola首先在其MC68HCXX系列处理器上定义的.SPI接口主要应用在 EEPROM,FLASH, ...

  5. 【VMware VCF】VMware Cloud Foundation Part 07:管理工作负载域中的主机和集群。

    一个标准 VMware Cloud Foundation 实例中具有管理工作负载域和 VI 工作负载域两种类型,管理域有且只有一个,而 VI 域可以创建多个,每种工作负载域中可以具有多个 vSpher ...

  6. 电子行业MES系统流程图梳理

  7. JavaScript设计模式样例十六 —— 备忘录模式

    备忘录模式(Memento Pattern) 定义:保存一个对象的某个状态,以便在适当的时候恢复对象.目的:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.场景:数据缓存. ...

  8. Spherical Voxelization

    Spherical Voxelization 标签: voxelization AI 摘要: 文档介绍了球面体素化的过程,包括重要的类和方法,如ConvertToSphericalVoxel和sphe ...

  9. Linux下编程常用基本命令

    Linux常用命令 基本操作命令 ls命令 ls -l # 列出文件和目录的详细信息 ls -R # 列出所有文件 ls -a # 列出隐藏文件 l;s # 列出 mv命令 mv example.tx ...

  10. 基于Material Design风格开源的Avalonia UI控件库

    前言 今天大姚给大家分享一款基于Material Design风格开源.免费(MIT License)的Avalonia UI控件库:Material.Avalonia. 当前项目还处于alpha阶段 ...