京公网安备 11010802034615号
经营许可证编号:京B2-20210330
01 前言
在日常的生活中,大家偶尔会看到朋友圈发的照片由一张被切成九张的效果,有时由一张照片被切成九张照片所带来的视觉盛宴是不一样的!
现在许多 P 图工具里面自带了这种功能,而微信小程序里也有专门可以切图的工具。为了熟练巩固的练习调库操作,今天就来带大家看看,如何用 Python 实现这个小功能。
02 成果展示
先来看看成果,原图为文章开始的图片,一图切九图朋友圈:
九张图发朋友圈的时候,还有个比较有意思的事,上传时是乱序的,还需要你自己像玩拼图一样自己摆位置。
03 思路讲解
这个小功能的实现利用了 Python 中的一个图形处理库,Pillow。
Pillow是由从著名的Python图像处理库PIL发展出来的一个分支,通过Pillow可以实现图像压缩和图像处理等各种操作。
1pip install pillow # 安装 pillow 库
大体实现思路以下几步:
04 代码讲解
按照上面的思路,写出代码:
1. 填充原图形的背景,生成大正方形图
1def fill_images(image):
2 """ 填充正方形白色背景图片 """
3 width, height = image.size # 获取图片的宽高
4 side = max(width, height) # 对比宽和高哪个大
6 # 新生成的图片是正方形的,边长取大的,背景设置白色
7 new_image = Image.new(image.mode, (side, side), color='white')
9 # 根据尺寸不同,将原图片放入新建的空白图片中部
10 if width > height:
11 new_image.paste(image, (0, int((side - height) / 2)))
12 else:
13 new_image.paste(image, (int((side - width) / 2), 0))
14 return new_image
代码中的顺序,可以理解为下面几个图形,首先在原有的照片基础上覆盖上白色背景:
其次,比较宽和高的生成规则是下面两个图,我们可以将背景调成黑色,便于观察,当宽大于高的像素时,你的照片就是横着铺满正方形的,而背景图填充上下,黑色背景是不是有股电影大片的气息:
当高大于宽的像素时,你的照片就是竖着铺满正方形的,而背景图填充左右:
第一步到这里就完成了,你得到的就是一张被背景颜色填满的正方形。
2. 对大正方形进行切割
1def cut_images(image):
2 """ 切割大正方形图 """
3 width, height = image.size
4 one_third_width = int(width / 3) # 三分之一正方形线像素
6 # 保存每一个小切图的区域
7 box_list =
9 """
10 切图区域是矩形,位置由对角线的两个点(左上,右下)确定,
11 而 crop 实际要传入四个参数(left, upper, right, lower)
12 """
13 for x in range(3):
14 for y in range(3):
15 left = x * one_third_width # 左像素
16 upper = y * one_third_width # 上像素
17 right = (x + 1) * one_third_width # 右像素
18 lower = (y + 1# 下像素
19 box = (left, upper, right, lower)
20 box_list.append(box)
21 image_list = [image.crop(box) for box in box_list]
22 return image_list
首先定位三分线:
根据左上,右下两个像素点的位置,确定新的图形:
最后将每个小正方形的左上和右下像素点进行存储,以元组的形式写到list中,在调用 crop 函数进行图像复制。关于 crop 函数,官方文档:
3. 存储切割后的9张图片(不放代码了,比较简单)
05 总结
Pillow 库对图像处理操作支持非常友好,而本次的小工具核心就在于如果进行对原有图片进行切割。内嵌两次循环来逐行遍历,双重遍历的思想会经常用到,这块可以注意下。
当然如果要是嫌源代码运行麻烦,可以打成 exe 文件来使用哟。这下又可以在朋友圈秀操作了!(比如改改背景呀,黑色背景什么的。)
CDA学员免费下载查看报告全文:2026全球数智化人才指数报告【CDA数据科学研究院】.pdf
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数据驱动运营的时代,指标是连接业务目标与实际行动的核心桥梁,是企业解读业务现状、发现问题、预判趋势的“量化标尺”。一套 ...
2026-05-08在存量竞争日趋激烈的商业时代,“以客户为中心”早已从口号落地为企业运营的核心逻辑。而客户画像作为打通“了解客户”与“服务 ...
2026-05-08 很多数据分析师每天与Excel打交道,但当被问到“什么是表格结构数据”“它和表结构数据有什么区别”“表格结构数据有哪些核 ...
2026-05-08在数据分析、计量研究等场景中,回归分析是探究变量间量化关系的核心方法,无论是简单的一元线性回归,还是复杂的多元线性回归、 ...
2026-05-07在数据分析、计量研究等场景中,回归分析是探究变量间量化关系的核心方法,无论是简单的一元线性回归,还是复杂的多元线性回归、 ...
2026-05-07 很多数据分析师画过趋势图、做过业绩预测,但当被问到“这个月销售额增长20%,到底是长期趋势自然增长,还是促销活动的短期 ...
2026-05-07在数字化时代,商业竞争的核心已从“经验驱动”转向“数据驱动”,越来越多的企业意识到,商业分析不是简单的数据统计与报表呈现 ...
2026-05-06在Excel数据透视表的实操中,“引用”是连接透视表与公式、辅助数据的核心操作,而相对引用作为最基础、最常用的引用方式,其设 ...
2026-05-06 很多数据分析师做过按月份的销售额趋势图,画过按天的流量折线图,但当被问到“时间序列和普通数据有什么本质区别”“季节性 ...
2026-05-06在Excel数据分析中,数据透视表是汇总、整理海量数据的高效工具,而公式则是实现数据二次计算、逻辑判断的核心功能。实际操作中 ...
2026-04-30Excel透视图是数据分析中不可或缺的工具,它能将透视表中的数据快速可视化,帮助我们直观捕捉数据规律、呈现分析结果。但在实际 ...
2026-04-30 很多数据分析师能熟练地计算指标、搭建标签体系,但当被问到“画像到底在解决什么问题”“画像和标签是什么关系”“画像如何 ...
2026-04-30在中介效应分析中,人口统计学变量(如年龄、性别、学历、收入、职业等)是常见的控制变量或调节变量,其处理方式直接影响分析结 ...
2026-04-29在SQL数据库实操中,日期数据的存储与显示是高频需求,而“数字日期”(如20240520、20241231、45321)是很多开发者、数据分析师 ...
2026-04-29 很多分析师在设计标签时思路清晰,但真到落地环节却面临“数据在手,不知如何转化为可用标签”的困境:或因加工方式选择不当 ...
2026-04-29在手游行业竞争日趋白热化的当下,“流量为王”早已升级为“留存为王”,而付费用户留存率更是衡量一款手游盈利能力、运营质量的 ...
2026-04-28在日常MySQL数据库运维与开发中,经常会遇到“同一台服务器上,两个不同数据库(以下简称“源库”“目标库”)的表数据需要保持 ...
2026-04-28 很多分析师每天和数据打交道,但当被问到“标签是什么”“标签和指标有什么区别”“标签体系如何设计”时,却常常答不上来。 ...
2026-04-28箱线图(Box Plot)作为一种经典的数据可视化工具,广泛应用于统计学、数据分析、科研实证等领域,核心价值在于直观呈现数据的集 ...
2026-04-27实证分析是社会科学、自然科学、经济管理等领域开展研究的核心范式,其核心逻辑是通过对多维度数据的收集、分析与解读,揭示变量 ...
2026-04-27