python可视化模块tkinter

#http://www.cnblogs.com/kaituorensheng/p/3287652.html(可视化 tkinter模块)、

#在线翻译:

import urllib.request
import urllib.parse
import json
from tkinter import *
from tkinter import ttk

class Translations(object):
    def __init__(self):
        self.root = Tk()
        self.root.title('Python翻译')
        self.root.resizable(width = False, height = False)

        
        self.s1 = ttk.Scrollbar(self.root)
        self.s2 = ttk.Scrollbar(self.root)
        self.text_1=Text(self.root,width=35,height=8,padx=10,pady=10,font=("微软雅黑", 13), relief = FLAT, yscrollcommand = self.s1.set)
        self.text_2=Text(self.root,width=35,height=8,padx=10,pady=10,font=("微软雅黑", 13), relief = FLAT, yscrollcommand = self.s2.set)
        self.right_click_menu_t1()
        self.right_click_menu_t2()
        self.quick_key()
        self.text_1.grid( row = 1, column  =0, columnspan = 2)
        self.text_2.grid( row = 4, column = 0, columnspan = 2)

        self.s1.grid(row = 1, column = 2, sticky = N + S)
        self.s2.grid(row = 4, column = 2, sticky = N + S)
        self.s1.config(command = self.text_1.yview)
        self.s2.config(command = self.text_2.yview)

        Label(self.root, text = '原文', fg = 'gray').grid(row = 0, sticky = W)
        Label(self.root, text = '译文', fg = 'gray').grid(row = 2, sticky = W)
        
        button_1 = Button(self.root, text = '翻译', font = ('微软雅黑', 8), command = self.translate, width = 10, relief = GROOVE)
        button_2 = Button(self.root, text = '清除', font = ('微软雅黑', 8), command = self.textclear, width = 10, relief = GROOVE)
        button_1.grid(padx = 2, pady = 2, row = 2, column = 0, sticky = E)
        button_2.grid(padx = 2, pady = 2, row = 2, column = 1, sticky = W)
        self.root.mainloop()
        
    def copytext_1(self):
        def select():
            try:
                return self.text_1.get(SEL_FIRST, SEL_LAST)
            except Exception:
                return ''
        aString = select()
        w.OpenClipboard()
        w.EmptyClipboard()
        w.SetClipboardData(win32con.CF_TEXT, aString.encode('gbk'))
        w.CloseClipboard()
    def getText_1(self):
        w.OpenClipboard()
        d = w.GetClipboardData(win32con.CF_TEXT)
        w.CloseClipboard()
        self.text_1.insert(INSERT, d.decode('gbk'))
        
    def copytext_2(self):
        def select():
            try:
                return self.text_2.get(SEL_FIRST, SEL_LAST)
            except Exception:
                return ''
        aString = select()
        w.OpenClipboard()
        w.EmptyClipboard()
        w.SetClipboardData(win32con.CF_TEXT, aString.encode('gbk'))
        w.CloseClipboard()
    def getText_2(self):
        w.OpenClipboard()
        d = w.GetClipboardData(win32con.CF_TEXT)
        w.CloseClipboard()
        self.text_2.insert(INSERT, d.decode('gbk'))
        
        
    def right_click_menu_t1(self):
        def right_menu(event):
            rightmenu.post(event.x_root, event.y_root)
        rightmenu = Menu(self.root, tearoff = False)
        rightmenu.add_command(label = '复制', command = self.copytext_1)
        rightmenu.add_command(label = '粘贴', command = self.getText_1)
        rightmenu.add_command(label = '清除', command = self.textclear)
        self.text_1.bind('<Button-3>', right_menu)
        
    def right_click_menu_t2(self):
        def right_menu(event):
            rightmenu.post(event.x_root, event.y_root)
        rightmenu = Menu(self.root, tearoff = False)
        rightmenu.add_command(label = '复制', command = self.copytext_2)
        rightmenu.add_command(label = '粘贴', command = self.getText_2)
        rightmenu.add_command(label = '清除', command = self.textclear)
        self.text_2.bind('<Button-3>', right_menu)
        
    def quick_key(self):
        self.text_1.bind('<Control-C>', self.copytext_1)
        self.text_1.bind('<Control-V>', self.getText_1)
        self.text_2.bind('<Control-C>', self.copytext_2)
        self.text_2.bind('<Control-V>', self.getText_2)
        
    def translate(self):
        content = self.text_1.get(1.0,END)
        self.text_2.delete(1.0, END)
        if content != '\n':
            url='http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=baidu'
            data={}
            data['type']='AUTO'
            data['i']=content
            data['doctype']='json'
            data['xmlVersion']='1.8'
            data['keyfrom']='fanyi.web'
            data['ue']='UTF-8'
            data['action']='FY_BY_CLICKBUTTON'
            data['typoResult']='true'
            data=urllib.parse.urlencode(data).encode('utf-8')
            req=urllib.request.Request(url,data)
            req.add_header('User_Agent','Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36')
            response=urllib.request.urlopen(req)
            html=response.read().decode('utf-8')
            target=json.loads(html)
            for i in target['translateResult']:
                for j in i:
                    self.text_2.insert(INSERT,j['tgt'])
                
    def textclear(self):
        self.text_1.delete(1.0, END)
        self.text_2.delete(1.0, END)
        
if __name__ == '__main__':
    Translations()


#其他 tkinter控件:

from Tkinter import *
root = Tk()
root.title("hello world")
root.geometry()

def print_item(event):
    print lb.get(lb.curselection())
    
var = StringVar()
lb = Listbox(root, height=5, selectmode=BROWSE, listvariable = var)
lb.bind('<ButtonRelease-1>', print_item)
list_item = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
for item in list_item:
    lb.insert(END, item)
    
scrl = Scrollbar(root)
scrl.pack(side=RIGHT, fill=Y)
lb.configure(yscrollcommand = scrl.set)
lb.pack(side=LEFT, fill=BOTH)
scrl['command'] = lb.yview

root.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、付费专栏及课程。

余额充值