tkinter之GUI小工具

from tkinter import *
import time
import hashlib
import string

LOG_LINE_NUM = 0

def set_init_window():
	init_window.title('GUI小工具V1.0')
	init_window.geometry('290x160+10+10')
	init_window['bg'] = 'pink'
	init_window.attributes('-alpha',8.8)
	
	

			
	
def set_window_graphy():

	global init_data_Text
	global result_data_label
	global log_label
	global result_data_Text
	global log_data_Text

	init_data_label = Label(init_window,text='待处理数据')
	init_data_label.grid(row=0,column=1)
	result_data_label = Label(init_window,text='输出结果')
	result_data_label.grid(row=0,column=20)
	log_label = Label(init_window,text='日志')
	log_label.grid(row=12,column=1)
	
	
	init_data_Text = Text(init_window,width=67,height=35)
	init_data_Text.grid(row=1,column=1,rowspan=10,columnspan=10)
	result_data_Text = Text(init_window,width=70,height=49)
	result_data_Text.grid(row=1,column=20,rowspan=15,columnspan=10)
	log_data_Text = Text(init_window,width=66, height=12)  # 日志框
	log_data_Text.grid(row=13, column=1,rowspan=10,columnspan=11)
	
	md5_button = Button(init_window, text="字符串转MD5", bg="lightblue", width=15,command=str_trans_to_md5)  # 调用内部方法  加()为直接调用
	md5_button.grid(row=1, column=12)
	
	sh256_button = Button(init_window, text="字符串转SHA256", bg="lightblue", width=15,command=str_trans_to_sha256)  # 调用内部方法  加()为直接调用
	sh256_button.grid(row=2, column=12)
	
	lowercase_button = Button(init_window, text="字符串全部转小写", bg="lightblue", width=15,command=str_trans_to_lowercase)  # 调用内部方法  加()为直接调用
	lowercase_button.grid(row=3, column=12)
	
	uppercase_button = Button(init_window, text="字符串全部转大写", bg="lightblue", width=15,command=str_trans_to_uppercase)  # 调用内部方法  加()为直接调用
	uppercase_button.grid(row=4, column=12)
	
	reversecase_button = Button(init_window, text="字符串全部翻转", bg="lightblue", width=15,command=str_trans_to_reversecase)  # 调用内部方法  加()为直接调用
	reversecase_button.grid(row=5, column=12)
	
def str_trans_to_md5():
	src = init_data_Text.get(1.0,END).strip().replace("\n","").encode()  #md5加密字符串必须是bytes类型,所以需要提前encode
	if src:
		try:
			myMd5 = hashlib.md5()
			myMd5.update(src)
			myMd5_Digest = myMd5.hexdigest()
			#print(myMd5_Digest)
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,myMd5_Digest)
			write_log_to_Text("INFO:str_trans_to_md5 success")
		except:
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,'INFO:str_trans_to_md5 failed')
			write_log_to_Text('INFO:str_trans_to_md5 failed')
	else:
		result_data_Text.delete(1.0,END)
		result_data_Text.insert(1.0,'INFO:no valid input')
		write_log_to_Text('INFO:no valid input')
		
		
def str_trans_to_sha256():
	src = init_data_Text.get(1.0,END).strip().replace("\n","").encode()  #sha256加密字符串必须是bytes类型,所以需要提前encode
	if src:
		try:
			mySha256 = hashlib.sha256()
			mySha256.update(src)
			mySha256_Digest = mySha256.hexdigest()
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,mySha256_Digest)
			write_log_to_Text("INFO:str_trans_to_sha256 success")
		except:
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,'ERROR:str_trans_to_sha256 failed')
			write_log_to_Text('ERROR:str_trans_to_sha256 failed')
	else:
		result_data_Text.delete(1.0,END)
		result_data_Text.insert(1.0,'ERROR:no valid input')
		write_log_to_Text('ERROR:no valid input')


def str_trans_to_lowercase():
	src = init_data_Text.get(1.0,END).strip()
	if src:
		try:
			lower_str = ''
			for i in src:
				if i.isalpha():
					lower_str+=i.lower()
				else:
					lower_str+=i
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,lower_str)
			write_log_to_Text("INFO:str_trans_to_lowercase success")
		except:
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,'ERROR:str_trans_to_lowercase failed')
			write_log_to_Text('ERROR:str_trans_to_lowercase failed')
	else:
		result_data_Text.delete(1.0,END)
		result_data_Text.insert(1.0,'ERROR:no valid input')
		write_log_to_Text('ERROR:no valid input')
		
		
		
def str_trans_to_uppercase():
	src = init_data_Text.get(1.0,END).strip()	
	if src:
		try:
			upper_str = ''
			for i in src:
				if i.isalpha():
					upper_str+=i.upper()
				else:
					upper_str+=i
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,upper_str)
			write_log_to_Text("INFO:str_trans_to_uppercase success")
		except:
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,'ERROR:str_trans_to_uppercase failed')
			write_log_to_Text('ERROR:str_trans_to_uppercase failed')
	else:
		result_data_Text.delete(1.0,END)
		result_data_Text.insert(1.0,'ERROR:no valid input')
		write_log_to_Text('ERROR:no valid input')		
		

def str_trans_to_reversecase():
	src = init_data_Text.get(1.0,END).strip()	
	if src:
		try:
			start = end = 0
			reversecase = ''
			for i in range(len(src)):
				if src[i] in string.punctuation:
					end = i
					reversecase += ' '.join(src[start:end].split()[::-1])
					reversecase += src[i]
					start = end+1

			if end != len(src)-1:
				end = len(src)-1
				reversecase += ' '.join(src[start:end].split()[::-1])
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,reversecase)
			write_log_to_Text("INFO:str_trans_to_reversecase success")
		except:
			result_data_Text.delete(1.0,END)
			result_data_Text.insert(1.0,'ERROR:str_trans_to_reversecase failed')
			write_log_to_Text('ERROR:str_trans_to_reversecase failed')
	else:
		result_data_Text.delete(1.0,END)
		result_data_Text.insert(1.0,'ERROR:no valid input')
		write_log_to_Text('ERROR:no valid input')	


		
def get_current_time():
	current_time = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
	return current_time
	
def write_log_to_Text(logmsg):
	global LOG_LINE_NUM
	current_time = get_current_time()
	log_msg = str(current_time)+' ' +str(logmsg)+'\n'
	if LOG_LINE_NUM <=7:
		log_data_Text.insert(END,log_msg)
		LOG_LINE_NUM = LOG_LINE_NUM + 1
	else:
		log_data_Text.delete(1.0,2.0)
		log_data_Text.insert(END,log_msg)
	log_data_Text.focus_force()
	

	
if __name__ == '__main__':
	init_window = Tk()
	set_init_window()
	set_window_graphy()
	init_window.mainloop()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPython等GUI,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值