m0_54183333 2021-06-21 11:06 采纳率: 0%
浏览 11

如何将界面的输入值放入到相应的位置

#导入库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