本文主要是介绍【Python】20行代码Excel画出Alice,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
代码如下,照着注释就能看懂了。简单来说就是使用OpenCV来获取图片大小以及像素,遍历给每个Excel格子赋上相应的颜色,同时设置一下列宽使得格子接近方形,这样就能在Excel中显示图片了。
Python Excel画图Demo
问题:
图片太大最后保存的Excel无法正常打开
git clone https://github.com/MisakaMikoto128/DrawExcel.git
from openpyxl.styles import PatternFill
from openpyxl.utils import get_column_letter
from openpyxl import Workbook
import cv2 as cv
def bgr2hex(bgr):(b, g, r) = (bgr)return hex(r << 16 | g << 8 | b).replace('0x','').zfill(6)
def 在Excel中画(img):W, H, C = img.shapefor w in range(W):sht.column_dimensions[get_column_letter(w + 1)].width = 2.15 #改列宽for h in range(H):sht.cell(w + 1, h + 1).fill = PatternFill("solid", fgColor=bgr2hex(img[w, h]))#给格子填充颜色
img = cv.imread("Alice2.jpg")#读取图片
wb = Workbook()#新建一个Workbook对象
sht = wb.worksheets[0]#打开第一张表单
# size = img.shape#获取图片大小(长,宽,通道数)
# img = cv.resize(img,(int(size[0]*0.5),int(size[1]*0.5)),cv.INTER_LINEAR)#缩放图片,图片太大会出问题
在Excel中画(img)
wb.save("Alice.xlsx")#保存
这篇关于【Python】20行代码Excel画出Alice的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!