使用Python实现产品图片自动化处理
大家好,在当今的数字化时代,产品图片在电子商务和市场营销中发挥着至关重要的作用。然而,为在线平台准备产品图片可能是一项耗时的任务,本文将分享一个Python脚本,用于自动化产品图片的图像处理工作流程。通过使用Python Imaging Library(PIL)和rembg库,可以实现删除图片背景,裁剪图片以适应产品尺寸,调整图片大小,并创建具有特定大小和颜色的新画布。
脚本概述
今天本文要讨论的脚本遵循以下步骤:
-
使用
rembg库删除图片背景。 -
裁剪图片,仅包含产品尺寸。
-
调整裁剪后的图片到指定的大小,同时保持宽高比。
-
创建具有指定大小和颜色的新画布。
-
将调整大小后的产品图片粘贴到新画布上。
安装和使用
要运行脚本,需要安装PIL(Pillow)库和rembg库。你可以使用pip安装它们:
pip install pillow rembg
要使用该脚本,请按照以下步骤操作:
-
将你的产品图片放置在指定的文件夹和子文件夹中。
-
在脚本中更新
folder_dir变量,以使其指向包含你的产品图片的文件夹。 -
使用Python解释器运行脚本。
脚本将处理文件夹及其子文件夹中的所有产品图片,应用前面提到的图像处理步骤。处理后的图像将进行保存,并在原始文件名后附加“_Processed”后缀。
函数解释
append_id(filename)
def append_id(filename):p = Path(filename)return "{0}_{2}{1}".format(Path.joinpath(p.parent, p.stem), ".png", "Processed")
此函数会在输出图像文件名附加一个ID。它以原始文件名作为输入,并返回附加了“_Processed”后缀的修改后的文件名。这有助于区分处理后的图像和原始图像。
autocrop_image(img, border=0)
def autocrop_image(img, border=0):bbox = img.getbbox()img = img.crop(bbox)(scale, height) = img.sizescale += border * 2height += border * 2cropped_image = Image.new("RGBA", (scale, height), (0, 0, 0, 0))cropped_image.paste(img, (border, border))return cropped_image
此函数通过删除任何不必要的空白或背景来自动裁剪图像,它接受一个输入图像img和一个可选border参数(默认为0),该参数用于在裁剪后的图像周围添加额外的填充。其使用img.getbbox()计算图像的边界框,将图像裁剪为边界框的内容,然后创建一个适当大小的新图像以容纳裁剪后的图像和边框,最后将裁剪后的图像粘贴到新图像上,并返回裁剪后的图像结果。
resize_image(img, myScale)
def resize_image(img, myScale):img_width, img_height = img.sizeif img_height > img_width:hpercent = (myScale/float(img_height))wsize = int((float(img_width)*float(hpercent)))resized_img = img.resize((wsize, myScale), Image.Resampling.LANCZOS)if img_width > img_height:wpercent = (myScale/float(img_width))hsize = int((float(img_height)*float(wpercent)))resized_img = img.resize((myScale, hsize), Image.Resampling.LANCZOS)return resized_img
此函数可在保持宽高比的同时缩放图像,接受输入图像img和所需缩放比例myScale。首先函数根据比较图像的高度和宽度来确定图像是纵向还是横向,然后使用所需的比例计算出相应的调整大小的尺寸,最后使用img.resize()根据计算出的尺寸调整图像大小,并返回调整大小后的图像。
resize_canvas(img, canvas_width, canvas_height)
def resize_canvas(img, canvas_width, canvas_height):old_width, old_height = img.sizex1 = int(math.floor((canvas_width - old_width) / 2))y1 = int(math.floor((canvas_height - old_height) / 2))mode = img.modeif len(mode) == 1:new_background = (255)if len(mode) == 3:new_background = (255, 255, 255)if len(mode) == 4:new_background = (255, 255, 255, 255)newImage = Image.new(mode, (canvas_width, canvas_height), new_background)newImage.alpha_composite(img, ((canvas_width - old_width) // 2, (canvas_height - old_height) // 2))return newImage
此函数可调整画布大小并将图像放置于其中,它接受输入图像img、画布宽度canvas_width和画布高度canvas_height。该函数根据画布尺寸与图像尺寸之间的差异,计算出将图像居中放置于画布上所需的位置,然后创建一个具有指定画布尺寸和根据图像模式确定的适当背景色的新图像。最后在计算出的位置将输入图像粘贴到新图像上,并返回调整画布尺寸后的图像。
process_files(folder_dir)
def process_files(folder_dir):for entry in os.scandir(folder_dir):if entry.is_file() and entry.name.lower().endswith(image_extensions):image_path = entry.pathimg = Image.open(image_path)output_path = append_id(image_path)removedBGimage = remove(img, True)croppedImage = autocrop_image(removedBGimage, 0)resizedImage = resize_image(croppedImage, 700)combinedImage = resize_canvas(resizedImage, 1000, 1000)combinedImage.save(output_path)elif entry.is_dir():process_files(entry.path)
此函数可处理指定文件夹及其子文件夹中的文件,以folder_dir作为输入,函数使用os.scandir()迭代遍历文件夹中的每个条目。如果条目是一个文件并且具有受支持的图像扩展名,它使用Image.open()打开该图像,然后通过调用append_id()函数生成输出路径,使用rembg库中的remove()函数删除图像背景,自动裁剪图像,调整图像大小,创建新画布,并将处理后的图像保存到输出路径。如果条目是一个目录,则它递归调用process_files()函数以处理子目录中的文件。
本文探讨了一个Python脚本,用于自动化产品图片的图像处理。通过充分利用PIL和rembg的功能,可以删除图像背景、裁剪图像、调整图像大小并创建新画布,以获得精美和专业的外观。通过自动化这一工作流程,可以节省准备产品图片用于各种电子商务和市场营销平台的时间和精力。
相关文章:
使用Python实现产品图片自动化处理
大家好,在当今的数字化时代,产品图片在电子商务和市场营销中发挥着至关重要的作用。然而,为在线平台准备产品图片可能是一项耗时的任务,本文将分享一个Python脚本,用于自动化产品图片的图像处理工作流程。通过使用Pyth…...
在CSDN学Golang云原生(git)
一,git的工作流程 Golang的Git工作流程与其他语言的Git工作流程类似,通常包括以下步骤: 创建分支:在本地代码库中创建一个新的分支,该分支用于开发新功能或修复错误。编写代码:在创建的分支上进行编码&am…...
QT多线程编程基础
文章目录 前言一、线程,进程 介绍二、创建线程三、终止线程总结 前言 一、线程,进程 介绍 线程: 是操作系统中独立运行的最小单位。每个线程都有自己的执行路径、程序计数器、堆栈和一组寄存器。线程共享进程的资源,如内存和文件…...
TRT4-trt-integrate - 3 使用onnxruntime进行onnx的模型推理过程
前言: onnx是microsoft开发的一个中间格式,而onnxruntime简称ort是microsoft为onnx开发的推理引擎。允许使用onnx作为输入进行直接推理得到结果。 py接口的推理过程: main函数: if __name__ "__main__":session onn…...
layui+drogon完成文件上传(简例)
layui界面加入按钮、文本框、进度条: <div class"layui-row"><button type"button" class"layui-btn" id"file_upload_control">文件上传</button><input type"file" id"files_input…...
高精度地图服务引擎项目
技术栈:使用vue3TypeScriptElement PlusPiniaaxios 项目描述:高精度地图服务引擎项目,提供轻量化处理3D瓦片切片分布式处理分发服务的一站式解决方案 工作内容:1、项目60%已上的页面开发 2、部分模块的功能实现, 3、封…...
PyTorch使用Transformer进行机器翻译
文章目录 简介数据集环境要求实验代码实验结果参考来源 简介 本文使用PyTorch自带的transformer层进行机器翻译:从德语翻译为英语。从零开始实现Transformer请参阅PyTorch从零开始实现Transformer,以便于获得对Transfomer更深的理解。 数据集 Multi30…...
LoadRunner使用教程
1. LoadRunner简介 LoadRunner是一款广泛使用的性能测试工具 可以对各种应用程序进行性能测试,包括Web应用程序、移动应用程序、企业级应用程序等。它提供了一个综合的性能测试解决方案,包括测试计划设计、脚本录制、测试执行、结果分析和报告生成等功…...
Zia和ChatGPT如何协同工作?
有没有集成ChatGPT的CRM系统推荐?Zoho CRM已经正式与ChatGPT集成。下面我们将从使用场景、使用价值和使用范围等方面切入讲述CRMAI的应用和作用。 Zia和ChatGPT如何协同工作? Zia和ChatGPT是不同的人工智能模型,在CRM中呈现出共生的关系。 …...
【位操作】——获取整数变量最低位为 1 的位置
获取整数变量最低位为 1 的位置 #define BIT_LOW_BIT(y) (((y)&BIT(0)) ? 0 : (((y)&BIT(1)) ? 1 : (((y)&BIT(2)) ? 2 : (((y)&BIT(3)) ? 3 : \(((y)&BIT(4)) ? 4 : (((y)&BIT(5)) ? 5 : (((y)&BIT(6)) ? 6 : (((y)&…...
gtest测试用例注册及自动化调度机制源代码流程分析
gtest的入门参见: 玩转Google开源C单元测试框架Google Test系列(gtest) gtest源码分析流程参见: gtest流程解析 测试用例注册流程分析要点:TEST_F宏替换、C静态成员的动态初始化。 自动化调度流程分析要点:UnitTest、UnitTestIm…...
IOS自动化测试环境搭建教程
目录 一、前言 二、环境依赖 1、环境依赖项 2、环境需求与支持 三、环境配置 1、xcode安装 2、Git安装 3、Homebrew安装(用brew来安装依赖) 4、npm和nodejs安装 5、libimobiledevice安装 6、idevicesinstaller安装 7、ios-deploy安装 8、Ca…...
常用API学习08(Java)
格式化 格式化指的是将数据按照指定的规则转化为指定的形式 。 那么为什么需要格式化?格式化有什么用? 以数字类为例,假设有一个比分牌,在无人得分的时候我们希望以:“00:00”的形式存在,那么…...
面试题-TS(八):什么是装饰器(decorators)?如何在 TypeScript 中使用它们?
面试题-TS(八):什么是装饰器(decorators)?如何在 TypeScript 中使用它们? 在TypeScript中,装饰器(Decorators)是一种用于增强代码功能的特殊类型声明。装饰器提供了一种在类、方法、…...
Jenkins 还可以支持钉钉消息通知?一个插件带你搞定!
Jenkins 作为最流行的开源持续集成平台,其强大的拓展功能一直备受测试人员及开发人员的青睐。大家都知道我们可以在 Jenkins 中安装 Email 插件支持构建之后通过邮件将结果及时通知到相关人员。 但其实 Jenkins 还可以支持钉钉消息通知,其主要通过 Ding…...
7.ES使用
ES多条件查询 and , or这种的 ES模糊查询 like这种的 {"wildcard": {"title.keyword": {"value": "*宣讲*"}}}说明: title是要匹配的关键字段名称keyword是属性,表示匹配的是关键字信息,如果不用.ke…...
Web安全基础
1、HTML基础 什么是 HTML HTML 是用来描述网页的一种语言。 HTML 指的是超文本标记语言 (Hyper Text Markup Language) HTML 不是一种编程语言,而是一种标记语言 (Markup language) 标记语言是一套标记标签 (Markup tag) HTML 使用标记标签来描述网页 总的来说&…...
jQueryAPI
文章目录 1.jQuery 选择器1.1 jQuery 基础选择器1.2 jQuery 层级选择器1.3 隐式迭代1.4 jQuery 筛选选择器1.5 jQuery 筛选方法1.6 jQuery 里面的排他思想1.7 链式编程 2.jQuery 样式操作2.1 操作 css 方法2.2 设置类样式方法2.3 类操作与className区别 3.jQuery 效果3.1 显示隐…...
如何将路径字符串数组(string[])转成树结构(treeNode[])?
原文链接:如何将路径字符串数组(string[])转成树结构(treeNode[])? 需求 这里的UI使用的是Element-Plus。 将一个路径字符串数组(当然也可能是其他目标字符串数组),渲染成树。 /*source:/a/b/c/d/e/a/b/e/f/g/a/b/h/a…...
中国工程院院士陈晓红一行莅临麒麟信安调研
7月20日下午,中国工程院院士、湘江实验室主任、湖南工商大学党委书记陈晓红,湘江实验室副主任、湖南工商大学副校长刘国权,湘江实验室副主任、湖南工商大学党委组织部统战部常务副部长胡春华等领导一行莅临麒麟信安调研。麒麟信安董事长杨涛&…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?
一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...
React Native在HarmonyOS 5.0阅读类应用开发中的实践
一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强,React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 (1)使用React Native…...
汇编常见指令
汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX(不访问内存)XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...
优选算法第十二讲:队列 + 宽搜 优先级队列
优选算法第十二讲:队列 宽搜 && 优先级队列 1.N叉树的层序遍历2.二叉树的锯齿型层序遍历3.二叉树最大宽度4.在每个树行中找最大值5.优先级队列 -- 最后一块石头的重量6.数据流中的第K大元素7.前K个高频单词8.数据流的中位数 1.N叉树的层序遍历 2.二叉树的锯…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...
短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...
处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
