#导入库from tkinter import *from PIL import Image#框架root = Tk()root.geometry('300x300')#标签1lb1 = Label(root,text='请输入图片名称',fg='red',font=('华文新魏',16),width=20,height=2,relief=GROOVE)lb1.grid(column=2,row=0)#文本框1inp1 = Entry(root,width=30, relief="sunken")inp1.grid(column=2,row=1)#确定按钮1def run1(): global filename filename = inp1.get()btn1 = Button(root, text='确定', command=run1)btn1.grid(column=4,row=1)#标签2lb2 = Label(root,text='请输入宽',fg='red',font=('华文新魏',16),width=20,height=2,relief=GROOVE)lb2.grid(column=2,row=2)#文本框2inp2 = Entry(root,width=30, relief="sunken")inp2.grid(column=2,row=3)#确定按钮2def run2(): global kuan kuan = inp2.get()btn2 = Button(root, text='确定', command=run2)btn2.grid(column=4,row=3)#标签3lb3 = Label(root,text='请输入高',fg='red',font=('华文新魏',16),width=20,height=2,relief=GROOVE)lb3.grid(column=2,row=4)#文本框3inp3 = Entry(root,width=30, relief="sunken")inp3.grid(column=2,row=5)#确定按钮3def run3(): global gao gao = inp3.get()btn3 = Button(root, text='确定', command=run3)btn3.grid(column=4,row=5)root.mainloop()def get_char(r,g,b,alpha=256): #判断alpha的值 if alpha == 0: #如果alpha等于0返回空格 return " " #将RGB的值转换为灰度值gary,灰度值范围为0-255 gary = (0.2126 * r + 0.7152 * g + 0.0722 * b) #gary/256==x/len(ascii_char) #字符集长度,70 ascii_char = list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'.") #灰度值范围是0-255,但字符集这里只有70,把灰度值映射到相应字符集上 x = int((gary/(alpha+1.0))*len(ascii_char)) #返回灰度值对应的字符 return ascii_char[x]#将返回的字符串放入创建文件中def write_file(out_file_name,content): #打开文件 with open(out_file_name,"w") as f: #写入字符串 f.write(content)def main(file_name="text.jpg",width=100,height=30,out_file_name="out_file"): #初始化输出的字符串 text = "" #打开图片文件并调整图片的宽和高 im = Image.open(file_name) im = im.resize((width,height),Image.NEAREST) #遍历图片中的每一行 for i in range(height): #遍历图片中该行中的每一列 for j in range(width): #将(j,i)坐标的RGB像素转为字符后添加到text字符串 content = im.getpixel((j,i)) text += get_char(*content) #遍历完一行后需要增加换行符 text += "\n" #输出到屏幕 print(text) write_file(out_file_name, text)#如果acii.py被当作python模块import的时候,这部分代码不会被执行if __name__== '__main__':#首先使用 PIL 的 Image.open 打开图片文件,获得对象 im#使用 PIL 库的 im.resize() 调整图片大小对应到输出的字符画的宽度和高度,注意这个函数第二个参数使用 Image.NEAREST,表示输出低质量的图片。#遍历提取图片中每行的像素的 RGB 值,调用 getchar 转成对应的字符#将所有的像素对应的字符拼接在一起成为一个字符串 txt#打印输出字符串 txt#如果执行时配置了输出文件,将打开文件将 txt 输出到文件,如果没有,则默认输出到 output.txt 文件 main(file_name="y.png.jpg") #文件的名字路径
1条回答 默认 最新
悬赏问题
- ¥15 Arduino红外遥控代码有问题
- ¥15 数值计算离散正交多项式
- ¥30 数值计算均差系数编程
- ¥15 redis-full-check比较 两个集群的数据出错
- ¥15 Matlab编程问题
- ¥15 训练的多模态特征融合模型准确度很低怎么办
- ¥15 kylin启动报错log4j类冲突
- ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
- ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序
- ¥15 onvif+openssl,vs2022编译openssl64