利用Python实现快速批量转换HEIC文件
作者:Python编程学习圈 发布时间:2022-08-01 08:41:35
1. 前言
最近打算做一批日历给亲朋好友,但是从 iPhone 上导出的照片格式是 HEIC 格式,而商家的在线制作网站不支持这种图片格式
PS:HEIC 是苹果采用的新的默认图片格式,它能在不损失图片画质的情况下,减少图片大小
有很多在线网站支持图片批量转换,但是安全隐私又没法得到保证;如果使用 PS 等软件去一张张转换,浪费时间的同时效率太低
本篇文章将使用 Python 批量实现 HEIC 图片文件的格式转换
2. 准备
首先,我们安装 pyheif 依赖包
Linux 和 Mac OS 可以通过下面链接选择合适的方式进行安装
https://pypi.org/project/pyheif/
如果是 Windows,我们只能下载 whl 依赖文件,使用 pip 命令进行安装
下载地址:
https://www.lfd.uci.edu/~gohl...
注意:我们需要根据系统及 Python 版本选择对应的文件进行安装
# 比如,本机是win10+64位 + Python3.7
# 通过下面链接下载文件:pyheif?0.6.1?cp37?cp37m?win_amd64.whl
https://www.lfd.uci.edu/~gohlke/pythonlibs/#pyheif
# 然后进行虚拟环境
# 使用pip3命令安装whl文件
pip3 install pyheif?0.6.1?cp37?cp37m?win_amd64.whl
然后,安装 PIL 依赖,用于图片处理
# 安装依赖
pip3 install Pillow
3. 实战
首先,遍历源文件夹及子文件夹,获取所有 HEIC 格式(不区分大小写)的图片
import pathlib
import os
def get_all_heic_imgs():
"""
获取所有heic格式的图片
:return:
"""
# heif_image_paths = glob.glob(r"{}/*.heic".format(source_path))
# 满足条件的文件列表
filelist = []
for root, dirnames, filenames in os.walk(source_path):
for filename in filenames:
# filename:文件名、root:文件对应的目录
# 获取文件后缀名
file_end = pathlib.Path(filename).suffix
# 文件名(不带后缀)
file_name = pathlib.Path(filename).name.split(".")[-2]
if file_end in ['.heic', '.HEIC']:
# 文件的完整目录
# file_path = os.path.join(root, filename)
filelist.append({
"filename": file_name,
"filepath": os.path.join(root, filename)
})
return filelist
然后,遍历文件列表,使用 pyheif 读取文件,使用PIL 转为二进制图片,以 JPG 格式保存到目标文件夹下
import pyheif
from PIL import Image
# 读取文件
img = pyheif.read(filepath)
img_bytes = Image.frombytes(mode=img.mode, size=img.size, data=img.data)
# 文件保存完整目录
target_file_path = '{}/{}_{}.jpg'.format(target_path, filename, generate_random_num(6))
# 保存
img_bytes.save(target_file_path, format="jpeg")
由于图片数目很多,图片读取、图片保存都是耗时的 IO 操作,最后对程序进行改造,利用多线程加快图片转换
另外,图片可能会存在文件名重名,最后保存的文件名追加了一个随机的字符串
import threading
def generate_random_num(count):
"""
产生一段随机的字符串
:param count:
:return:
"""
return ''.join(random.sample('abcdefghijklmnopqrstuvwxyz', count))
def convert_heic_to_jpg(file, semaphore):
"""
heic格式转jpg
:param files:
:return:
"""
semaphore.acquire()
...
#文件操作
# 释放
semaphore.release()
if __name__ == '__main__':
...
# 定义信号量,并发处理文件IO
semaphore = threading.BoundedSemaphore(20)
for file in files:
t = threading.Thread(target=convert_heic_to_jpg, args=(file, semaphore))
t.start()
4.最后
通过上面的操作就可以快速将 HEIC 文件批量转换为 JPG 文件,当然如果想转为其他图片,比如:PNG,只需要更改 PIL 保存图片的格式即可
来源:https://segmentfault.com/a/1190000042212776


猜你喜欢
- python记录程序运行时间的三种方法 &nb
- 本文实例为大家分享了python人脸识别程序,大家可进行测试#coding:utf-8 import cv2 import sys from
- 1、 数据库闭包表简介像MySQL这样的关系型数据库,比较适合存储一些类似表格的扁平化数据,但是遇到像树形结构这样有深度的数据,就很难驾驭了
- 前言左思右想没有头绪时,刚好看到一篇介绍Pygame制作飞机大战的文章。文章写的不错,文中代码拿来就能跑。有了!要不直接把飞机大战改成接兔子
- 目录前言1. 效果图2. 原理3. 源码3.1 Numpy实现傅里叶变换3.2 OpenCV实现傅里叶变换3.3 HPF or LPF?参考
- 此文用来正式回复大辉同学的疑问。1、结论:固定宽度只适合功能型网站,不适合希望用户认真阅读的浏览型网站。UCD大社区是浏览型网站,它的定位是
- 前言&最近因为一些原因,没有更博客,昨天老师布置了一个作业,用vue实现增删改查功能,想想这也不难,就做一下试试吧。因为自己写的样式
- 本文实例讲述了python简单的函数定义和用法。分享给大家供大家参考。具体分析如下:这里定义了一个温度转换的函数及其用法。def conve
- 通过AngularJS实现图片上传及缩略图展示示例,废话不多说了,具体如下:从项目中截出的代码HTML部分:<section>
- 注意:我用的python2.7,大家如果用Python3.0以上的版本,请记得在print()函数哦!如果因为版本问题评论的,不做回复哦!!
- 本文研究的主要是Python进程间通信Queue的相关实例,具体如下。1.Queue使用方法:Queue.qsize():返回当前队列包含的
- 本文实例讲述了Python MongoDB 插入数据时已存在则不执行,不存在则插入的解决方法。分享给大家供大家参考,具体如下:前言:想把QQ
- 编程需求:使用python+opencv对图像进行处理,把两张图放在一起显示方法:使用numpy模块中的水平堆叠或竖直堆叠完成所有图像的堆叠
- Firefox 2.0 在对 XML 的支持方面有几个重要的改进。目前它的用户部署如日中天。了解 Firefox 2.0 XML 特性的改进
- 在我的使用SQL Server2005的新函数构造分页存储过程中,我提到了使用ROW_NUMBER()函数来代替top实现分页存储过程。 但
- windows下python安装pip 简易教程,具体内容如下1.前提你要已经安装了 某个 版本的 python, 下载地址)安装后,需要配
- 前言今天就来理一理session、cookie、token这三者之间的关系!1.为什么会有它们?我们都知道 HTTP 协议是无状态的,所谓的
- 不多说,直接上代码from hdfs import Clientimport pandas as pdHDFSHOST = "ht
- 每次在操作数据库的时候最烦的就是根据表单提交的内容写sql语句,特别是字段比较多的时候很麻烦,动不动就容易写错。所以我就写了下面的生成sql
- 在任何有监督机器学习项目的模型构建阶段,我们训练模型的目的是从标记的示例中学习所有权重和偏差的最佳值。如果我们使用相同的标记示例来测试我们的