百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

怎么做到的?用python制作九宫格图片,太棒了

ztj100 2025-05-11 03:06 29 浏览 0 评论

1. 应用场景

当初的想法是:想把一张图切割成九等份,发布到微信朋友圈,切割出来的图片,上传到朋友圈,发现微信不按照我排列的序号来排版。这样的结果是很耗时间的。让我深思,能不能有一种,直接拼接成一张九宫格图呢。经过重新设计后,答案是可以的。

是这样实现的:

1.先创建一张(黑白灰)图(尺寸与原图一样大(可能略微小1-2px像素)尺寸创建是程序内部完成的无需我们干预,黑白灰是我们自己创建的))

2.把原图的每一份添加到刚创建的黑白灰图里。

3.导出拼接好的九份图。

4.手画简易图纸,实现过程图:

2. 代码实现

1. 依赖库安装:

pip install pillow

2. 以下源码保存在文件名“九宫格应用.py”里:

from PIL import Image
import numpy as np
import PIL
import os

def user_input():
    #返回图片质量参数,和访问图片地址和保存图片地址
    name = input("输入文件夹名称:") #用户创建的文件夹
    space = int(input("\n定义九宫格的间隙输入4的倍数:")) #用户创建的文件夹
    aq = int(input('\n输入0 代表油画效果,50 代表发朋友圈效果 ,100 代表是最高清效果: '))
    first_color = int(input('\n输入0-255之间的数,0代表黑色线条,254代表白色线条,1-253之间代表灰色线条: '))
    if first_color >= 0 and first_color<=254: #背景颜色值判断,不在这个区域,统一定义背景色为黑色
        end_color = first_color +1  
    else:
        first_color = 0 #代表黑色
        end_color = first_color +1 
    file_path= os.getcwd()+"\\"+name+"\\"  #访问图片路径
    save_path = os.getcwd()+"\\"+"九宫格_"+name+"\\"  #保存图片路径
    if not os.path.exists(save_path): 
        os.makedirs(save_path) #创建要保存的文件夹
    names = os.listdir(file_path) #获取要访问的图片文件名
    dir_list = [] #定义一个列表,存放访问和保存地址
    for n in names: #循环提取文件名
        req_dir = file_path +n #访问地址拼接
        save_dir = save_path +n #保存地址拼接
        dir_list.append((n,req_dir,save_dir)) #存入列表里
    return (first_color,end_color,space,name,aq,dir_list) #返回图片质量和访问和保存路径

def img_split_9(first_color,end_color,space,n,aq,req_dir,save_dir):
    try: #这里可能会出错,因为文件夹里的文件有些可能不是图片格式的。
        img = Image.open(req_dir).convert("RGB")#读取图片
    except(PIL.UnidentifiedImageError):
        return #结束本次运行
    n_img = np.array(img)#把图片转换成数字
    hv_wv = n_img.shape #获取图片的高与宽值
    hv = hv_wv[0] #高值
    wv = hv_wv[1] #宽值
    h_av = hv//3 #高的均值
    w_av = wv//3 #宽的均值 
    white_color = np.random.randint(first_color,end_color,size=(h_av*3+space,w_av*3+space,3),dtype='uint8') #创建自定义背景色,尺寸比原图大space个像素
    for i in range(3):#i代表高度(行)
        for j in range(3):#j代表宽度(列)
            white_color[h_av*i+i*(space//2):h_av*(i+1)+i*(space//2),w_av*j+j*(space//2):w_av*(j+1)+j*(space//2)] = n_img[h_av*i:h_av*(i+1),w_av*j:w_av*(j+1)]     #这是九等份算法,把原图的每一份图添加到背景图里。
    img_hwv = Image.fromarray(white_color)
    img_hwv.save(save_dir,'JPEG',quality=aq) #aq代表图片压缩质量,0代表是接近油画效果,50代表中等效果图,发朋友圈用的。100代表接近原图,大小比原图大一点。
    print('{}拼接ok'.format(n))

def main():
    first_color,end_color,space,name,aq,dir_list = user_input() #获取用户输入的参数值
    for n,req_dir,save_dir in dir_list:
        img_split_9(first_color,end_color,space,n,aq,req_dir,save_dir) #九宫格制作启动
    print('\n拼接结束了,打开"九宫格_{}"文件看一下,是否转换成功吧!\n'.format(name))   #告诉使用者,图片保存文件夹
  
if __name__ == "__main__":
    print('使用说明:\n 1、把九宫格应用.exe文件或者九宫格应用.py放在要转换的文件夹旁边,\n 2、然后双击九宫格应用.exe文件或者启动cmd python 九宫格应用.py按照提示输入文件夹的名称等,\n 3、同时按下ctrl+c键,强行退出\n') #使用说明
    while True:
        try:
            main()
        except(ValueError):
            print('请按照提示输入: \n')

3. 启动过程

1.先把“九宫格应用.py”放在要处理的图片文件夹旁边,本例子使用的文件名为“photock_images”,效果如下图所示:

2.在“九宫格应用.py”旁边空白处,按下键盘“shift"键同时按下鼠标右键,弹出一个对话框,找到“在此处打开命令窗口(W )" 如下图所示:

3.启动“九宫格应用.py”,在打开的终端里,输入 python 九宫格应用.py 然后按下键盘的Enter键,按照提示输入后,然后按下键盘的Enter键。效果如下图所示:

4.程序处理完成后,在“photock_images”旁边出现一个名为“九宫格_photock_images"的文件夹,效果如下图所示:


4. 成品展现

1.程序执行前的图片效果:

2.程序执行后的图片效果:

相关推荐

sharding-jdbc实现`分库分表`与`读写分离`

一、前言本文将基于以下环境整合...

三分钟了解mysql中主键、外键、非空、唯一、默认约束是什么

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。...

MySQL8行级锁_mysql如何加行级锁

MySQL8行级锁版本:8.0.34基本概念...

mysql使用小技巧_mysql使用入门

1、MySQL中有许多很实用的函数,好好利用它们可以省去很多时间:group_concat()将取到的值用逗号连接,可以这么用:selectgroup_concat(distinctid)fr...

MySQL/MariaDB中如何支持全部的Unicode?

永远不要在MySQL中使用utf8,并且始终使用utf8mb4。utf8mb4介绍MySQL/MariaDB中,utf8字符集并不是对Unicode的真正实现,即不是真正的UTF-8编码,因...

聊聊 MySQL Server 可执行注释,你懂了吗?

前言MySQLServer当前支持如下3种注释风格:...

MySQL系列-源码编译安装(v5.7.34)

一、系统环境要求...

MySQL的锁就锁住我啦!与腾讯大佬的技术交谈,是我小看它了

对酒当歌,人生几何!朝朝暮暮,唯有己脱。苦苦寻觅找工作之间,殊不知今日之事乃我心之痛,难道是我不配拥有工作嘛。自面试后他所谓的等待都过去一段时日,可惜在下京东上的小金库都要见低啦。每每想到不由心中一...

MySQL字符问题_mysql中字符串的位置

中文写入乱码问题:我输入的中文编码是urf8的,建的库是urf8的,但是插入mysql总是乱码,一堆"???????????????????????"我用的是ibatis,终于找到原因了,我是这么解决...

深圳尚学堂:mysql基本sql语句大全(三)

数据开发-经典1.按姓氏笔画排序:Select*FromTableNameOrderByCustomerNameCollateChinese_PRC_Stroke_ci_as//从少...

MySQL进行行级锁的?一会next-key锁,一会间隙锁,一会记录锁?

大家好,是不是很多人都对MySQL加行级锁的规则搞的迷迷糊糊,一会是next-key锁,一会是间隙锁,一会又是记录锁。坦白说,确实还挺复杂的,但是好在我找点了点规律,也知道如何如何用命令分析加...

一文讲清怎么利用Python Django实现Excel数据表的导入导出功能

摘要:Python作为一门简单易学且功能强大的编程语言,广受程序员、数据分析师和AI工程师的青睐。本文系统讲解了如何使用Python的Django框架结合openpyxl库实现Excel...

用DataX实现两个MySQL实例间的数据同步

DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的...

MySQL数据库知识_mysql数据库基础知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

如何为MySQL中的JSON字段设置索引

背景MySQL在2015年中发布的5.7.8版本中首次引入了JSON数据类型。自此,它成了一种逃离严格列定义的方式,可以存储各种形状和大小的JSON文档,例如审计日志、配置信息、第三方数据包、用户自定...

取消回复欢迎 发表评论: