使用Python实现的Excel像素画

简介:本项目主要使用python语言,将图片转为 Excel,图片中的每一个像素转化为 Excel 中的每一个单元格。主要使用pillow和xlsxwriter这两个模块。项目使用一个python文件即可。

一:项目功能和流程介绍

项目的主要功能:就是将一张人脸图像,画在Excel表格上,图片的每一个像素点对应Excel的一个格子,俗称像素画。

流程:

  • 创建 Excel 表,并设置行高和列宽
  • 打开图片
  • 遍历图片每一个像素点
  • 提取每个像素点的颜色
  • 颜色填充对应的单元格

注意:

  • 图片尺寸过大:进行缩放
  • 颜色过多(Excel 不支持):减少颜色

模块:

  • pillow:图像处理库
  • xlsxwriter:创建 Excel 文件的模块

 二:主要代码及运行结果

 首先在项目下创建一个python文件,命名为:pricture_to_xlsx.py。

from PIL import Image  # 导入PIL库中的Image模块
import xlsxwriter  # 导入xlsxwriter库DEFAULT_EXCEL_NAME = 'nic.xlsx'  # 默认的Excel文件名
DEFAULT_MAX_WIDTH = 500  # 默认最大宽度
COLOR_REDUCE_LEVEL = 5  # 颜色减少级别def image_to_excel(pic_file, output_file=DEFAULT_EXCEL_NAME, max_width=DEFAULT_MAX_WIDTH):# 检查传入参数类型是否正确if not isinstance(pic_file, str) or not isinstance(output_file, str):print("参数错误,请检查传入的参数类型")return# 打开图片并调整大小img = Image.open(pic_file)  # 使用PIL库打开传入的图片文件img_height = img.height  # 获取图片高度img_width = img.width  # 获取图片宽度if img.width > max_width:  # 如果图片宽度超过最大宽度img_height = int(max_width / img_width * img_height)  # 根据比例调整高度img_width = max_width  # 将宽度设为最大宽度img = img.resize((img_width, img_height))  # 调整图片大小# 创建 Excel 表,并设置行高和列宽workbook = xlsxwriter.Workbook(output_file)  # 创建一个Excel文件worksheet = workbook.add_worksheet()  # 在Excel文件中添加一个工作表worksheet.set_default_row(9)  # 设置默认行高worksheet.set_column(0, img_width, width=1)  # 设置列宽# 遍历图片每一个像素点for x in range(img_width):  # 遍历宽度for y in range(img_height):  # 遍历高度# 提取每个像素点的颜色color = img.getpixel((x, y))  # 获取像素点的颜色# 减少颜色种类color = tuple([x - x % COLOR_REDUCE_LEVEL for x in color])  # 减少颜色种类# 颜色填充对应的单元格worksheet.write(y, x, '', workbook.add_format({'bg_color': '#%02X%02X%02X' % color}))  # 在单元格中填充颜色# 关闭工作簿workbook.close()if __name__ == '__main__':# 转换图片到Excelimage_to_excel('F:/桌面文件夹/cxk.jpg')  # 调用函数将图片转换为Excel

准备好我们的图片如下,然后运行我们的pricture_to_xlsx.py文件得到nic.xlsx的文件。

运行文件,生成打开nic.xlsx文件后如下图所示。 

 感谢阅读!!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/257290.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2023年5个自动化EDA库推荐

EDA或探索性数据分析是一项耗时的工作,但是由于EDA是不可避免的,所以Python出现了很多自动化库来减少执行分析所需的时间。EDA的主要目标不是制作花哨的图形或创建彩色的图形,而是获得对数据集的理解,并获得对变量之间的分布和相关…

如何将Word中的表格图片转换为可编辑格式?

我们都知道,Word中的表格是一个非常有用的工具,可以让我们在文档中轻松添加和编辑各种数据。但有时候我们可能会遇到一个问题:当表格作为图片插入时,我们就不能直接编辑它了。这可怎么办呢? 别担心,我们有…

小电流MOSFET 选型分析数据,可应用于电子烟,电动工具,智能穿戴等产品上

小电流双N,D-N通道MOSFET,电压60V-100V左右 电流300mA-500MA,采用封装形式多样。具有低导通电阻,可快速切换速度,易于设计的驱动电路也易于并联,ESD保护,低电压驱动使该器件非常适合便携式设备…

PHP使用mkcert本地开发生成HTTPS证书 PhpEnv集成环境

PHP使用mkcert本地开发生成HTTPS证书 PhpEnv集成环境 前言一、介绍 mkcert二、安装/使用 mkcert1. 安装2. 使用 总结 前言 本地开发时有些功能只有在 https 证书的情况下才能使用, 例如一些 Web API 一、介绍 mkcert Github地址 mkcert 是一个制作本地可信开发证书的简单工具。…

2024年度AI策略报告:AI浪潮扬帆起航,传媒应用百花齐放

今天分享的人工智能系列深度研究报告:《2024年度AI策略报告:AI浪潮扬帆起航,传媒应用百花齐放》。 (报告出品方:兴业证券) 报告共计:52页 1、行情回顾:板块处于较低区间&#xff0…

编程怎么学才能快速入门,分享一款中文编程工具快速学习编程思路,中文编程工具之分组框构件简介

一、前言: 零基础自学编程,中文编程工具下载,中文编程工具构件之扩展系统菜单构件教程 编程系统化教程链接 https://jywxz.blog.csdn.net/article/details/134073098?spm1001.2014.3001.5502 给大家分享一款中文编程工具,零基础…

深度学习训练过程自查:为什么我的模型不收敛/表现不佳?

代码终于写完了,bug 处理好了,终于跑起来了。但是模型不收敛。或者收敛了,但是加 trick 也表现不良。看着这个精心编写的辣鸡模型,从内心深处生出一股恨铁不成钢的悲愤。 于是开始思考,为什么?哪里出了问题…

【TwinCAT学习笔记 1】TwinCAT开发环境搭建

写在前面 作为技术开发人员,开启任何一项开发工作之前,首先都要搭建好开发环境,所谓磨刀不误砍材工,一定要有耐心,一次不行卸载再装。我曾遇到过一个学生,仅搭建环境就用了两周,这个过程也是一…

AI创作系统ChatGPT网站源码,AI绘画,支持GPT联网提问/即将支持TSS语音对话功能

一、AI创作系统 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统,支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI…

mybatis数据输出-map类型输出

1、建库建表 create table emp (empNo varchar(10) null,empName varchar(100) null,sal int null,deptno varchar(10) null ); 2、pom.xml <dependencies><dependency><groupId>org.mybatis</groupId><artifactId>mybatis<…

centOS使用docker部署ElasticSearch和Kibana

一、docker部署ElasticSearch 1、创建网桥 docker network create xybnet 2、下载镜像 docker pull elasticsearch:8.2.0 3、先运行容器 docker run -d \ --name es \ --net xybnet \ -p 9200:9200 \ -p 9300:9300 \ -p 5601:5601 \ -e "discovery.typesing…

web前端实现LED功能、液晶显示时间、数字

MENU 效果演示html部分JavaScript部分css部分 效果演示 html部分 <div id"app"><!-- 页面 --><div class"time-box"><!-- 时 --><div class"house-box"><bit-component :num"houseTem"></bit…