python:tkinter用bind绑定双击事件不成功?

工具:win10 python3.4 tkinter
最近学习python遇到奇怪的问题:
这段程序就是画了一个text文本框,然后绑定一个双击事件,当双击时打印出“双击”可是打印不出来,奇怪的是程序刚运行时却打印出“双击”,之后双击却不打印,有人知道是什么问题吗?

代码如下:

import tkinter
from tkinter import *
def p():
print('双击')
root=tkinter.Tk()
text=tkinter.Text(root,width=30,height=5)
text.pack()
text.bind("",p())
root.mainloop()

图片说明

2个回答

life_1m
life_1m 我已经是按这个贴来做的,结果不行!是不是我电脑设置问题?
4 个月之前 回复

已经解决了!
def p():
改为
def p(self):

text.bind("",p())
改为
text.bind("",p)

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Python的tkinter模块,通过给Button添加事件绑定改变其state失败。

Python的tkinter模块,通过给Button添加事件绑定改变其state失败,请问这是为什么,附上代码如下 ![图片说明](https://img-ask.csdn.net/upload/201703/09/1489036463_131680.png) 测试结果输出 relief的样式为sunken,但实际窗口上的button标签样式并未改变,请问这是什么问题,如何实现改变relief

python tkinter中button怎么绑定多个变量

我想了好久,想不到解决办法。 我是用tkinter+selenium,一键启动几个浏览器。 是考虑多线程吗?还是本身command可以直接绑定多个变量? 求指点解决思路最好,比如怎么查看button的command的使用。。。。。 然后再考虑多线程或者别的什么? 我实在是小白,大神别见笑,提点两句给个方向,谢谢

tkinter 双击 打开文件

我现在想做一个软件,用python的tkinter查找文件,找到以后双击就可以打开。 怎么处理? ``` # coding:utf-8 #usr/bin/env python from Tkinter import * import tkFileDialog #弹出选择路径的库 import tkMessageBox import os import fnmatch #选择文件的关键词 def left(): if not entry.get() :#检测关键词输入框是否为空 tkMessageBox.showerror("提示信息:","出现以下错误:\n关键词不能为空")#弹出警告框 return #如果为空不再执行 list_box.delete(0,END) path = tkFileDialog.askdirectory()#弹出选择路径的窗口,path为获取的路径 path_list = os.walk(path)#获取一个列表目录的对象 for root, dirs, files in path_list: #print root, dirs, files for i in files: if(entry.get()==os.path.splitext(i)[0]): list_box.insert(END, root+"/"+i) ?????? root = Tk() root.title('文件搜索')#创建窗口 root.geometry('+400+200')#窗口大小,窗口位置 #1.输入关键词 Label(text=' 关键词: ').grid(row=0,column=0)# 创建标签 entry = Entry()#输入框实例化 entry.grid(row=0,column=1)#输入框 Button(text=' 选择文件夹', command=left).grid(row=0,column=4)#按钮 list_box = Listbox(width=80) list_box.grid(row=1, column=0, columnspan=5)#显示列表框 loop = mainloop()#显示窗口 ``` 在中间的??????位置应该用什么代码 可以双击得到的文件,就可以打开了

Python tkinter图形界面BUTTON事件控制和编辑框返回值出现异常

使用win7的Python3.73的IDLE界面编写图形界面程序,在编码过程中发现,如果定义一个主窗口后再定义一个局部窗口会导致后面的窗口的编辑框设置和取值异常。具体问题用一个测试程序来说明如下: ``` import tkinter as tk from tkinter import messagebox def newwin(title='test',geometry='300x300'): def ShowMessage(): tk.messagebox.showinfo(input.get()) window = tk.Tk() window.title(title) window.geometry(geometry) input = tk.StringVar() input.set('请输入任意内容!') tk.Label(window, text='请输入任意内容: ').place(x=10, y= 10) entry_new_name = tk.Entry(window, textvariable=input) entry_new_name.place(x=150, y=10) btn_show = tk.Button(window, text='显示输入', command=ShowMessage) btn_show.place(x=80, y=90) btn_newwin = tk.Button(window, text='新弹窗', command=newwin) btn_newwin.place(x=150, y=90) btn_exit = tk.Button(window, text='退出', command=exit) btn_exit.place(x=220, y=90) return window root = newwin() root.mainloop() ``` 上述代码执行后,显示一个窗口,内有:一个输入框,三个按钮,一个是显示输入框内容,一个是再次新建一个同样的窗口,一个是系统退出。执行后第一次打开窗口时相关功能正常,但当选择“新弹窗”弹出一个新的窗口后,编辑框的初始内容没有显示,且输入内容后,在新窗口显示编辑框的内容取得的值为变量初始化的值,没有取得新的输入。 关于以上代码,有如下几个问题: 1、为什么新弹窗中编辑框的显示和变化没有和变量关联起来? 2、上述代码中btn_newwin按钮定义如果改为:“btn_newwin = tk.Button(window, text='新弹窗', command=newwin)”中,如果newwin使用带实参格式,则会导致一启动就会不停新建窗口,导致递归调用过深异常出现才终止?这是为什么 ? 3、该代码存储到文件后,使用dos命令行方式执行文件无任何反应。是图形界面的程序无法在非图形界面解释器下执行吗?该怎么解决? 非常抱歉,本人没有C币,不知可有哪位大拿免费指教?谢谢!

求大神看看!python3 tkinter 的问题,文本框不能获取内容。

用tkinter 写一个窗口, a=Tk() a.title('欢迎使用成绩管理系统') f=Frame(a) f.pack(padx=80, pady=40, ipadx=20)#f为块容器 窗口里加一个文本框, u1=StringVar() Entry(f,textvariable=u1).grid(row=1,column=1,padx=5,pady=10) 写一个按钮事件 Button(f,text='登陆',command=submit1).grid(row=3,column=0,padx=10,pady=10) submit是获取u1中的文本,一点问题没有! 然而,窗口里面还有一个按钮是注册,点击注册是创建一个新窗口,但是,用get获取新窗口的文本框内容时,就会没反应,获取不到。 困扰了很久 ,调试很久,没有变量和语法错误。 跪求 谢谢

Python关于Tkinter的多线程问题

使用TKinter编写界面,实现选择测试用例并执行,最后打印出测试结果。功能是实现了,可是每次一点下开始执行,整个界面就失去响应了,要等到测试用例执行完了,界面才恢复响应,已经把执行用例和画界面分别作为单独的线程来处理了,为什么还是不行? 界面如下: ![图片说明](https://img-ask.csdn.net/upload/201512/22/1450763641_583787.png) 相关代码如下: def ExcuteSet(): global Exe_Flag Exe_Flag=True #执行测试用例 exe_thread= threading.Thread(target=ExecuteCase) exe_thread.setDaemon(True) exe_thread.start() exe_thread.join() def Interface(): global ComX,Baud,TBuf global txt1,txt2,txt3 # 界面 root.title(u'自动化测试工具') root.geometry('800x600') #滚动条 scroll1=Tk.Scrollbar(root,orient=Tk.VERTICAL) #滚动条 scroll1.pack(fill="y",side='right') txt1 = Tk.Text(root,width=60,height=20,border=5,yscrollcommand=scroll1.set) txt1.pack(side='right',padx=3,pady=1,anchor='c') txt1.bind("<Key>",TextKey) scroll1.config(command=txt1.yview) txt1.place(x=300,y=300) #scroll1.place(x=750,y=300) #操作按钮 TBuf = StringVar() cnv1 = tk.Canvas(root,height=260,width=260) cnv1.pack(side='bottom',padx=0,pady=0,anchor='c') cnv1.create_window(60,40,window=ttk.Label(root,text=u'串口号: ')) cnv1.create_window(165,40,window=ttk.Combobox(root,textvariable=ComX,values=['COM1', 'COM2', 'COM3','COM4','COM5', 'COM6', 'COM7','COM8'],width=12)) cnv1.create_window(60,80,window=ttk.Label(root,text=u'波特率: ')) cnv1.create_window(165,80,window=ttk.Combobox(root,textvariable=Baud,values=['4800','9600','14400','19200','38400','57600','115200'],width=12)) cnv1.create_window(70,120,window=ttk.Label(root,text=u'输入目录: ')) cnv1.create_window(240,120,window=ttk.Entry(root,textvariable=TBuf,width=40)) cnv1.create_window(80,150,window=ttk.Button(root,textvariable=OpenOff,command=COMOpen,width=12)) cnv1.create_window(80,180,window=ttk.Button(root,text=u'选择用例',command=SelectCase,width=12)) cnv1.create_window(80,210,window=ttk.Button(root,text=u'开始执行',command=ExcuteSet,width=12)) cnv1.create_window(80,240,window=ttk.Button(root,text=u'停止测试',command=StopTest,width=12)) cnv1.create_window(175,180,window=ttk.Button(root,text=u'清除用例',command=ClearCase,width=12)) cnv1.place(x=320,y=0) #滚动条 scroll2=Tk.Scrollbar(root,orient=Tk.VERTICAL) #滚动条 scroll2.pack(fill="y",side='left') #显示测试用例 txt2 = Tk.Text(root,width=40,height=20,border=5,yscrollcommand=scroll2.set) txt2.pack(padx=3,pady=1,anchor='c') scroll2.config(command=txt2.yview) txt2.place(x=0,y=0) scroll2.place(x=300,y=0) #显示测试用例执行情况 txt3 = Tk.Text(root,width=40,height=20,border=5) txt3.pack(padx=3,pady=1,anchor='c') txt3.place(x=0,y=300) root.mainloop() if __name__=='__main__': isOpened.clear() Init() #初始化 Opencom() threads=[] #读串口数据 com_thread = threading.Thread(target=COMTrce) threads.append(com_thread) #画界面 inter_thread = threading.Thread(target=Interface) threads.append(inter_thread) #执行用例 #exe_thread= threading.Thread(target=ExecuteCase) #threads.append(inter_thread) for t in threads: t.setDaemon(True) t.start() for t in threads: t.join() print "Over!!!!!!!!!!!" ``` ```

Python中用tkinter创建GUI时,设置窗口大小,总是报错,求各位大神指导!

``` from tkinter import * root = Tk() root.title('My First Tk') root.geomtry('150x200') root.mainloop() ``` 报错信息: Traceback (most recent call last): File "G:/Lab/01jsq/jsq/main.py", line 9, in <module> root.geomtry('150x200') File "C:\Users\bitla\AppData\Local\Programs\Python\Python37-32\lib\tkinter\__init__.py", line 2101, in __getattr__ return getattr(self.tk, attr) AttributeError: '_tkinter.tkapp' object has no attribute 'geomtry' 真心不知道哪里出问题了,求各位大佬指导,跪谢!

Python-Tkinter请问有什么办法可以在事件处理过程中,即时刷新Text的信息?

新手刚学了Thinter,我用了for循环往文本框里添加信息,,用的insert方法,点击按钮后结果如下图所示,,表面上看不出控制台的结果跟Text组件的结果有啥区别,,但是事实上左边的Text的信息是4秒后才把添加的四条信息刷新出来的,,然而看到信息里面的用time方法打印出的时间戳确实方法已经处理过…… 也就是说事件发生-循环语句中处理好但是要方法结束后,事件产生的组件信息才会刷新出来? ``` def test(): for i in range(1,5): i=i*1.0 print(time.time()) t4.insert(i,'hello--'+str(time.time())+'\n') if i==4: break time.sleep(1) print(time.time()) b2=Button(frm_l,width=10,command=test) ``` ![图片说明](https://img-ask.csdn.net/upload/201507/09/1436439793_929807.jpg) 那请问有什么办法可以在事件处理过程中,即时刷新Text的信息? 补充一下,其实搞这个Text信息,,就是为了使用时候可以看到程序的一些运行情况。。我是想把方法的运行情况的返回值(把原本打印到控制台的提示信息变成方法的返回值)都直接显示到Text文本框里面,这是比较直观的方法。 然而事实上现在却卡在这里。或者换个思路,,有什么办法让别人(没有安装python环境)使用打包后的exe程序的时候看到控制台里面的信息。。

python中tkinter的text问题

在文本框插入内容,我们用text.insert('insert',...) 但这种做法是添加式的插入,可以进行覆盖式的插入吗? 大神们指教

关于python tkinter的问题

我用tkinter的时候,为什么button按钮绑定了函数,运行以后函数就自动运行了 from tkinter import * from stock_system.updata.tushare_data_updata import tushare_update def update(): tu = tushare_update() tu.update_sql() root = Tk() # 通过command属性来指定Button的回调函数 Button(root, text='Hello Button', command=update).pack() root.mainloop()

python3 tkinter Entry组件获取输入内容,通过button组件运行失败

修改之前没有通过Entry 输入框来获取文件地址,修改后手动输入地址就会报错,小白求助。。。。。。。 修改之前 ``` from PIL import Image import tkinter as tk root = tk.Tk() input01 = tk.Entry() input01.pack() def dakai(): fullpath = "C:/Users/PJN1SZH/Desktop/New folder/background.gif" image = Image.open(fullpath,'r') image.show() button = tk.Button(root,text = 'dsadasda',command = dakai) button.pack() root.mainloop() ``` 修改后 ``` from PIL import Image import tkinter as tk root = tk.Tk() input01 = tk.Entry() input01.pack() fullpath = input01.get() def dakai(): image = Image.open(fullpath,'r') image.show() button = tk.Button(root,text = 'dsadasda',command = dakai) button.pack() root.mainloop() ``` ![图片说明](https://img-ask.csdn.net/upload/201901/16/1547610042_402101.png)

在python-tkinter中一个按钮正在触发状态下触发另一个按钮?

![图片说明](https://img-ask.csdn.net/upload/202003/21/1584762096_611414.png) 如图我已经触发了Start按钮,且按照项目要求Start按钮触发的程序要持续运行,那么此时我应该如何触发Quit按钮? ``` def start(): cap = cv2.VideoCapture(0) detector = dlib.get_frontal_face_detector() predictor = dlib.shape_predictor('F:\\shape_predictor_68_face_landmarks.dat\\shape_predictor_68_face_landmarks.dat') while True: ret, frame = cap.read() dets = detector(frame, 1) if len(dets) > 0: for i, d in enumerate(dets): x, y, w, h = d.left(),d.top(),d.right(),d.bottom() cv2.rectangle(frame, (x - 10, y - 10), ( w + 10, h + 10), (0, 255, 0), 2) shape = predictor(frame, d) for index, pt in enumerate(shape.parts()): pt_pos = (pt.x, pt.y) cv2.circle(frame, pt_pos, 1, (255, 0, 0), 2) font = cv2.FONT_HERSHEY_SIMPLEX cv2.putText(frame, str(index+1),pt_pos,font, 0.3, (0, 0, 255), 1, cv2.LINE_AA) cv2.imshow('frame', frame) cap.release() cv2.destroyAllWindows() ```

python tkinter如何与线程通讯?

如题,现有主线程(tkinter线程)和一辅助线程,现在要求辅助线程将某些信息投到某列表里,并由GUI线程进行调用 请问如何实现?

在Python的GUI(tkinter)中,使用for循环添加多给个Entry组件,如何能够对这多个组件在光标离开后(focusout)进行验证?

在Python的GUI(tkinter)中,使用for循环添加多给个Entry组件,如何能够对这多个组件在光标离开后(focusout)进行验证? 代码如下: ``` from tkinter import * from tkinter import messagebox B_number = [] def C(): def row(): obtain_number = row_number.get() if obtain_number.isdigit(): if eval(obtain_number) > 10: messagebox.showinfo("提示","输入行数太多!,最多总计10行") row_number.delete(0,END) row_number.insert(0,"2") else: def judge_B(event): if B.get().isdigit(): print("成功") else: messagebox.showerror("错误","重新输入") a = eval(obtain_number)+1 for i in range(1,a): B = Entry(add) B.bind("<FocusOut>",judge_B) B_number.append(B) B.grid(row = len(B_number)+1,column = 2) else: messagebox.showerror("错误","字符不合法,已修改为2!") row_number_ene.delete(0,END) row_number_ene.insert(0,"2") add = Tk() add.title("行业绿色制造分级判定系数") add.geometry("500x500") Label(add,text = "行数: ").grid(row = 0,column = 0,padx = 5,pady = 10) row_num = StringVar() row_num.set("2") row_number = Entry(add,textvariable = row_num,bg = "grey",width = 7, justify = CENTER) row_number.grid(row =0,column = 1,pady = 10) Button(add,text = "增加多行",command = row).grid(row = 0, column = 2,pady = 10) C() ``` 存在问题,假设我添加两行,然后对每一行输入1,循环输入(即,第一行输入1-第二行输入1-第一行输入1-第二行输入1,第一行输入a,第二行输入a,第一行输入a,第二行 输入a,每次输入后,点上面行数 (避免多次点击)) 输出结果依次为: 报错;(这里应该是成功才对) 成功; 成功; 成功; 成功;(这里应该报错才对) 报错; 报错; 报错 小弟没有C币,还希望大神能帮忙解决下,小弟在此先行感谢

python使用tkinter调用新窗口,被调用的窗口点击右上角关闭按钮会报错,怎么屏蔽按钮

主窗口中写了一个按钮调用一个函数,打开一个新的窗口 ``` def ask_wifi(self): inputDialog =getWifi.MyDialog() self.wait_window(inputDialog) return inputDialog.wifi ``` 新的窗口中需要点击选择并返回选择内容,选择遇到一个问题,点击右上角关闭按钮x的时候会报错,有什么帮忙屏蔽按钮或者处理这个报错,新窗口代码: ``` import tkinter as tk from tkinter import * around_wifi=['1','2','3'] class MyDialog(tk.Toplevel):#wifi选择界面 def __init__(self): super().__init__() self.title('wifi') self._setup_UI() def _setup_UI(self): self.wifi_listbox=Listbox(self) self.wifi_listbox.bind('<Double-Button-1>',self.ok) for str in around_wifi: self.wifi_listbox.insert(END,str) self.wifi_listbox.grid() def ok(self,i): wifi=self.wifi_listbox.get(self.wifi_listbox.curselection()) self.wifi=[wifi] print('wifi:',wifi) self.destroy() return self.wifi ``` 报错如下: AttributeError: 'MyDialog' object has no attribute 'wifi'

Python_tkinter关于主窗口和弹窗的控件的显示

请各位大佬指教,谢谢 :) 目的:主窗口选择通讯类型,选定后显示弹窗内容,同时隐藏主窗口;弹窗关闭后,主窗口恢复。 问题:选择通讯类型后,弹窗内无任何内容,关闭弹窗(还没添加弹窗的destroy,现在是直接右上角的×),发现主窗口的界面被弹窗的内容覆盖,没弄明白为什么会显示到主窗口去 : ( ``` import tkinter as tk from tkinter import ttk # import SocketTest # import time class TcpTool(tk.Tk): def __init__(self): super().__init__() self.modeSelected = tk.StringVar() self.canvas = tk.Canvas(self, width=500, height=400) self.background = tk.PhotoImage(file=r'E:\picture3.gif') self.dispalyBackground = self.canvas.create_image(250, 0, anchor='n', image=self.background) self.combobox = ttk.Combobox(self, textvariable=self.modeSelected) self.combobox['value'] = ('', ' TCP-Server', ' TCP-Client', ' UDP') self.combobox.current(0) # self.mode = tk.Label(text='Communicate Mode') # self.displayBackground.pack() # self.combobox.place() self.combobox.bind("<<ComboboxSelected>>", self.newWindow) self.canvas.place(x=0, y=0) self.canvas.create_window(100, 80, width=100, height=20, window=self.combobox) # self.canvas.create_window(150,50,width=130,height=20,window=self.mode) self.title('Communicate Tools') self.geometry('500x300') self.resizable(False, False) self.mainloop() def donothing(self): pass def newWindow(self, event_type): if self.combobox.get() == ' TCP-Server': mydialog = NewDialog(1) elif self.combobox.get() == ' TCP-Client': mydialog = NewDialog(2) elif self.combobox.get() == ' UDP': mydialog = NewDialog(3) else: return self.withdraw() self.wait_window(mydialog) self.update() self.deiconify() return class NewDialog(tk.Toplevel): def __init__(self, event): super().__init__() self.title('Communicate Tools') self.geometry('680x500') # self.resizable(False, False) self.wm_attributes('-topmost', 1) self.frame_top = tk.Frame(width=640, height=80, bg='grey') self.frame_center_left = tk.Frame(width=310, height=250, bg='blue') self.frame_center_right = tk.Frame(width=310, height=250, bg='yellow') self.frame_bottom = tk.Frame(width=640, height=100, bg='purple') self.localIp = tk.IntVar() self.localPort = tk.IntVar() self.destinationIp = tk.IntVar() self.destinationPort = tk.IntVar() self.sendEntry = tk.StringVar() self.acceptEntry = tk.StringVar() self.click = tk.StringVar() self.connectStatus = 0 self.localIp.set('172.168.155.167') self.localPort.set('9000') self.destinationIp.set('172.168.155.166') self.destinationPort.set('9001') self.sendEntry.set('Enter data to send') # self.acceptEntry.set('data get from destination ') tk.Label(self.frame_top, text='Local IP:', width=10, height=1, font=('Arial', 12) ).place(x=20, y=10) tk.Label(self.frame_top, text='Local Port:', width=10, height=1, font=('Arial', 12)).place(x=20, y=46) tk.Entry(self.frame_top, textvariable=self.localIp, font=('Arial', 13), width=14).place(x=125, y=10) tk.Entry(self.frame_top, textvariable=self.localPort, font=('Arial', 13), width=14).place(x=125, y=46) tk.Checkbutton(self.frame_top, text='连接', width=8, variable=self.click, font=('幼圆', 11), cursor='arrow', selectcolor='red', relief='sunken', justify=tk.CENTER, onvalue=1, offvalue=0, command=self.socConnect, indicatoron=False).place(x=560, y=10) self.socketStatus = tk.Label(text='', width=9, bg='red').place(x=572, y=56) self.remoteAddress = tk.Label(self.frame_top, text='Destination IP', width=15, height=1, font=('Arial', 12)) self.remotePort = tk.Label(self.frame_top, text='Destination Port', width=15, height=1, font=('Arial', 12)) self.enter_remoteAddress = tk.Entry(self.frame_top, textvariable=self.destinationIp, font=('Arial', 13), width=14) self.enter_remotePort = tk.Entry(self.frame_top, textvariable=self.destinationPort, font=('Arial', 13), width=14) self.remoteAddress.place(x=270, y=10) self.remotePort.place(x=270, y=46) self.enter_remoteAddress.place(x=420, y=10) self.enter_remotePort.place(x=420, y=46) tk.Entry(self.frame_center_left, textvariable=self.sendEntry, font=('Arial', 12)).place(x=10, y=220) self.sendAreaText = tk.Text(self.frame_center_left, width=33, height=10, font=('Arial', 11)) self.sendAreaScroll = tk.Scrollbar(self.frame_center_left, orient='vertical', command=self.sendAreaText.yview) self.sendAreaText.configure(yscrollcommand=self.sendAreaScroll.set) self.send = tk.Label(self.frame_center_left, text='Send Area', width=10, height=1, font=('Arial', 12)) self.sendAreaScroll.place(x=278, y=100) self.sendAreaText.place(x=10, y=35) self.send.place(x=107, y=5) # tk.Entry(self.frame_center_right, textvariable=self.acceptEntry, font=('Arial', 12)).place(x=10, y=10) self.acceptAreaText = tk.Text(self.frame_center_right, width=33, height=10, font=('Arial', 11)) self.acceptAreaScroll = tk.Scrollbar(self.frame_center_right, orient='vertical', bd=50, command=self.acceptAreaText.yview) self.acceptAreaText.configure(yscrollcommand=self.acceptAreaScroll.set) self.accept = tk.Label(self.frame_center_right, text='Accept Area', width=10, height=1, font=('Arial', 12)) self.acceptAreaScroll.place(x=278, y=100) self.acceptAreaText.place(x=10, y=35) self.accept.place(x=107, y=5) self.frame_top.grid(row=0, column=1, columnspan=3, padx=10, pady=10) self.frame_center_right.grid(row=1, column=0, columnspan=2, padx=10, pady=5) self.frame_center_left.grid(row=1, column=2, columnspan=2, padx=5, pady=5) self.frame_bottom.grid(row=2, column=0, columnspan=3, padx=10, pady=10) self.frame_top.grid_propagate(0) self.frame_center_left.grid_propagate(0) self.frame_center_right.grid_propagate(0) self.frame_bottom.grid_propagate(0) def socConnect(self): pass if __name__ == '__main__': L = TcpTool() ```

Python使用tkinter实时动态显示图像闪烁问题?

global img_ global laser_map # 地图数据,从服务器收到数据,先解码 laser_map = base64.b64decode(msg) file_image = open('build_map.png', 'wb+') file_image.write(laser_map) img_ = Image.open("build_map.png",) width, height = img_.size # 做旋转操作 if width < height: self.rotate_flag = True img_.rotate(90, expand=True).save('build_map_rotate.png') else: self.rotate_flag = False img_.rotate(0, expand=True).save('build_map_rotate.png') self.zoom_map_image = Image.open('build_map_rotate.png') # PIL project tranform into PhotoImage project laser_map = ImageTk.PhotoImage(self.zoom_map_image) self.laser = self.canvas_map.create_image(self.canvas_center_x, self.canvas_center_y, anchor='center',image=laser_map) self.canvas_map.place(x=0, y=0)

python中用tkinter加email写邮件发送系统

用tkinter的button添加文件 但是email模块中都是对单一文件处理的函数 有没有可以处理任意文件格式的函数 还是需要用后缀名去判断格式 然后再用相应的函数?求解。

关于tkinter的notebook问题

![图片说明](https://img-ask.csdn.net/upload/202002/01/1580541360_699863.png) 一个窗口上有四个页面,希望可以右键点击其中任意一个可以将其那一页关闭 ,试了很多次,def add_note 的第三行必须是 bind note,而不能是tab,但是改成note就变为,点击notebook任意一个地方都会删除其中一个,而不是想删哪个是哪个 原意:是想做一个类似漫画下载器一样的东西,在输入框内输入搜索的东西后,会弹出一个notebook的新的一页,之后想关闭的时候就可以将其关闭,类似选项卡一样 顺便问一下,tkinter有没有想浏览器里的选项卡一样有 ‘x’ 号 代码如下: class a: def destroy(self, event): self.note.forget(self.tab) def add_note(self, text): self.tab = Frame(self.note) self.note.add(self.tab, text=text) self.note.bind('<Button-3>', self.destroy) def main(self): root = Tk() root.geometry('500x400') self.note = Notebook(root) self.tab1 = Frame(self.note) tab2 = Frame(self.note) self.note.add(self.tab1, text='热门推荐') self.note.add(tab2, text='推荐') self.note.pack() self.add_note('123') self.add_note('123') root.mainloop() a().main()

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

点沙成金:英特尔芯片制造全过程揭密

“亚马逊丛林里的蝴蝶扇动几下翅膀就可能引起两周后美国德州的一次飓风……” 这句人人皆知的话最初用来描述非线性系统中微小参数的变化所引起的系统极大变化。 而在更长的时间尺度内,我们所生活的这个世界就是这样一个异常复杂的非线性系统…… 水泥、穹顶、透视——关于时间与技艺的蝴蝶效应 公元前3000年,古埃及人将尼罗河中挖出的泥浆与纳特龙盐湖中的矿物盐混合,再掺入煅烧石灰石制成的石灰,由此得来了人...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

C++11:一些微小的变化(新的数据类型、template表达式内的空格、nullptr、std::nullptr_t)

本文介绍一些C++的两个新特性,它们虽然微小,但对你的编程十分重要 一、Template表达式内的空格 C++11标准之前建议在“在两个template表达式的闭符之间放一个空格”的要求已经过时了 例如: vector&lt;list&lt;int&gt; &gt;; //C++11之前 vector&lt;list&lt;int&gt;&gt;; //C++11 二、nullptr ...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

深入剖析Springboot启动原理的底层源码,再也不怕面试官问了!

大家现在应该都对Springboot很熟悉,但是你对他的启动原理了解吗?

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

【阿里P6面经】二本,curd两年,疯狂复习,拿下阿里offer

二本的读者,在老东家不断学习,最后逆袭

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

微软为一人收购一公司?破解索尼程序、写黑客小说,看他彪悍的程序人生!...

作者 | 伍杏玲出品 | CSDN(ID:CSDNnews)格子衬衫、常掉发、双肩包、修电脑、加班多……这些似乎成了大众给程序员的固定标签。近几年流行的“跨界风”开始刷新人们对程序员的...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

我说我懂多线程,面试官立马给我发了offer

不小心拿了几个offer,有点烦

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

立即提问
相关内容推荐