欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python 制作一個gui界面的翻譯工具

 更新時間:2021年05月14日 16:52:36   作者:懷淰メ  
圖形界面總是比命令行的程序更加好用,也更容易給新手使用,今天就來介紹如何使用python制作一個圖形界面的翻譯工具

一.準(zhǔn)備工作

除了Tkinter,還需要google_trans_new,沒有安裝這個庫的朋友,可以使用

pip install google_trans_new

安裝一下。

二.預(yù)覽

1.主界面

2.翻譯

3.支持多種語言哦

三.源代碼

設(shè)計流程很簡單,這里就直接貼代碼了

3.1 My_Translator-v2.0.py

from tkinter import *
from tkinter import messagebox
from tkinter import ttk
import pyperclip
import threading
from tkinter.filedialog import askopenfilename
from Translator import Do_Trans

"""
使用combobox進行語言記錄
"""

class App:
    def __init__(self):
        self.window=Tk()
        self.window.title('翻譯器-v2.0')
        width=480
        height=480
        left=(self.window.winfo_screenwidth()-width)/2
        top=(self.window.winfo_screenheight()-height)/2
        self.window.geometry('%dx%d+%d+%d'%(width,height,left,top))
        self.window.resizable(0,0)
        self.create_widget()
        self.set_widget()
        self.place_widget()
        self.language='auto'
        self.window.mainloop()

    def create_widget(self):
        self.l1=ttk.Label(self.window)
        self.t1=Text(self.window)
        self.b1=ttk.Button(self.window)
        self.b2=ttk.Button(self.window)
        self.b3=ttk.Button(self.window)
        self.l2=ttk.Label(self.window)
        self.t2=Text(self.window)
        self.Scroll_vertical1 = Scrollbar(self.window, orient=VERTICAL)
        self.Scroll_vertical2 = Scrollbar(self.window, orient=VERTICAL)
        self.Scroll_level = Scrollbar(self.window, orient=HORIZONTAL)
        self.m=Menu(self.window)
        self.window['menu']=self.m
        self.l3=ttk.Label(self.window)


    def set_widget(self):
        self.l1.config(text='待翻譯文本',font=('宋體',10))
        self.b1.config(text='清空輸入框',command=lambda:self.thread_it(self.clear_t))
        self.b2.config(text='翻譯',command=lambda:self.thread_it(self.do_translate))
        self.b3.config(text='復(fù)制翻譯內(nèi)容',command=lambda:self.thread_it(self.copy_t))
        self.l2.config(text='翻譯結(jié)果',font=('宋體',10))
        self.Scroll_vertical1.config(command=self.t1.yview)
        self.t1['yscrollcommand'] = self.Scroll_vertical1.set
        self.Scroll_vertical2.config(command=self.t2.yview)
        self.t2['yscrollcommand'] = self.Scroll_vertical2.set
        self.t2['xscrollcommand']=self.Scroll_level.set
        self.s1=Menu(self.m,tearoff=False)
        self.s2=Menu(self.m,tearoff=False)
        self.s3=Menu(self.m,tearoff=False)
        self.m.add_cascade(label='文件',menu=self.s1)
        self.m.add_cascade(label='操作',menu=self.s2)
        self.m.add_cascade(label='關(guān)于',menu=self.s3)
        self.s1.add_command(label='打開文本文件',command=self.open_txt)
        self.s1.add_separator()
        self.s1.add_command(label='退出',command=self.quit_window)
        self.s2.add_command(label='翻譯',command=lambda:self.thread_it(self.do_translate))
        self.s2.add_command(label='選擇語言',command=self.open_topleval)
        self.s2.add_command(label='清空內(nèi)容',command=self.clear_t)
        self.s2.add_command(label='復(fù)制結(jié)果',command=lambda:self.thread_it(self.copy_t))
        self.s3.add_command(label='說明',command=self.show_infos)
        self.l3_var=StringVar()
        self.l3.config(textvariable=self.l3_var,background='lightblue')
        self.l3_var.set('當(dāng)前[自動選擇]目標(biāo)語言')
        self.window.bind('<Escape>',self.escape)
        self.t1.bind('<Return>',lambda:self.thread_it(self.do_translate))
        self.window.protocol('WM_DELETE_WINDOW',self.quit_window)
        self.menubar = Menu(self.t1,tearoff=False)
        self.menubar.add_command(label="粘貼", command=self.do_paste)
        self.t1.bind('<Button-3>',self.paste)
        self.menubar2 = Menu(self.t2,tearoff=False)
        self.menubar2.add_command(label="粘貼", command=self.do_paste2)
        self.t2.bind('<Button-3>',self.paste2)
        self.current_select=0

    def place_widget(self):
        self.l1.place(x=200,y=5)
        self.t1.place(x=10,y=30,height=150,width=450)
        self.Scroll_vertical1.place(x=445,y=30,height=150)
        self.b1.place(x=10,y=200)
        self.b2.place(x=180,y=200)
        self.b3.place(x=370,y=200)
        self.l2.place(x=200,y=228)
        self.t2.place(x=10,y=250,height=180,width=450)
        self.Scroll_vertical2.place(x=445,y=250,height=180)
        self.Scroll_level.place(x=10,y=430,width=450)
        self.l3.place(x=0,y=450,width=480,height=30)

    def open_topleval(self):
        self.select_lan_window=Toplevel()
        width=250
        height=50
        left=(self.select_lan_window.winfo_screenwidth()-width)/2
        top=(self.select_lan_window.winfo_screenheight()-height)/2
        self.select_lan_window.geometry('%dx%d+%d+%d'%(width,height,left,top))
        self.select_lan_window.resizable(0,0)
        self.s_combobox_var=StringVar()
        self.language_table=Do_Trans().get_language_table()
        self.s_combobox=ttk.Combobox(self.select_lan_window,textvariable=self.s_combobox_var,justify='center',state='readonly',width=17,value=[language['language'] for language in self.language_table])
        #對當(dāng)前選中語言進行記錄
        if self.current_select==0:
            self.s_combobox.current(0)
        else:
            self.s_combobox.current(self.current_select)
        self.s_b1=ttk.Button(self.select_lan_window,text='選擇',command=self.select_lan)
        self.s_combobox.pack(side=LEFT)
        self.s_b1.pack(side=RIGHT)
        self.select_lan_window.mainloop()


    def select_lan(self):
        self.current_select=self.s_combobox.current()
        self.now_language=self.language_table[self.s_combobox.current()]['language']
        messagebox.showinfo('提示',f'當(dāng)前選擇 [{self.now_language}] 作為目標(biāo)語言')
        self.l3_var.set(f'選擇[{self.now_language}]作為目標(biāo)語言')
        self.now_lan=self.language_table[self.s_combobox.current()]['short']
        self.select_lan_window.destroy()

    def open_txt(self):
        txt_path = askopenfilename(title='選擇一個txt文本文件',filetypes=[('txt source file','*.txt')])
        if txt_path:
            self.t1.delete('0.0',END)
            with open(txt_path,'r',encoding='utf-8')as f:
                for line in f.readlines():
                    self.t1.insert(END,line)
            f.close()

    def paste(self,event):
        self.menubar.post(event.x_root,event.y_root)


    def do_paste(self):
        self.t1.insert(END,pyperclip.paste())

    def paste2(self,event):
        self.menubar2.post(event.x_root,event.y_root)


    def do_paste2(self):
        self.t2.insert(END,pyperclip.paste())

    def escape(self,event):
        self.quit_window()

    def quit_window(self):
        ret=messagebox.askyesno('退出','是否要退出?')
        if ret:
            self.window.destroy()

    def do_translate(self):
        try:
            self.aim_language=self.now_lan
        except AttributeError:
            self.aim_language= self.language
        self.t2.delete('0.0',END)
        text=self.t1.get('0.0',END)
        if len(text)!=1:
            self.l3_var.set('正在翻譯...')
            t=Do_Trans()
            result=t.translate(text,self.aim_language)
            if result:
                self.l3.config(background='lightblue')
                self.t2.insert(END,result.strip())
                try:
                    self.l3_var.set(f'翻譯完成...已翻譯為[{self.now_language}]')
                except AttributeError:
                    self.l3_var.set(f'翻譯完成...已[自動選擇目標(biāo)語言]')

            else:
                self.l3_var.set('翻譯失敗,請檢查網(wǎng)絡(luò)!')
                self.l3.config(background='red')
        else:
            messagebox.showwarning('警告','請輸入內(nèi)容!')
            self.l3.config(background='red')
            self.l3_var.set('請輸入內(nèi)容')

    def clear_t(self):
        self.t1.delete('0.0',END)
        self.t2.delete('0.0',END)

    def copy_t(self):
        tr_res=self.t2.get('0.0',END)
        pyperclip.copy(tr_res)
        spam = pyperclip.paste()
        if spam:
            self.l3.config(background='lightyellow')
            self.l3_var.set('復(fù)制成功!')

    def show_infos(self):
        messagebox.showinfo('說明','作者:懷淰メ')

    def thread_it(self,func,*args):
        t=threading.Thread(target=func,args=args)
        t.setDaemon(True)
        t.start()

if __name__ == '__main__':
    a=App()

3.2 Translator.py

from google_trans_new import google_translator
import re

class Do_Trans():

    def get_language_table(self,):
        lan_table1 = lan_table.strip().replace("'", '')
        names = re.findall(r'[\u4e00-\u9fa5()]+', lan_table1)
        lans = re.findall(r'[^\u4e00-\u9fa5 \s:()]+', lan_table1)
        language_table = []
        for language in zip(names, lans):
            item = {}
            item['language'] = language[0]
            item['short'] = language[1]
            language_table.append(item)
        return language_table

    def translate(self,text,language):
        try:
            t=google_translator().translate(text,language)
            return t
        except:
            return False
lan_table='''
'自動選擇': 'auto'
'南非荷蘭語': 'af'
'阿爾巴尼亞語': 'sq'
'阿姆哈拉語': 'am'
'阿拉伯語': 'ar'
'亞美尼亞語': 'hy'
'阿塞拜疆語': 'az'
'巴斯克語': 'eu'
'白俄羅斯語': 'be'
'孟加拉語': 'bn'
'波斯尼亞語': 'bs'
'保加利亞語': 'bg'
'加泰羅尼亞語': 'ca'
'宿務(wù)語': 'ceb'
'中文(簡體)': 'zh'
'中文(繁體)': 'zh-TW'
'科西嘉語': 'co'
'克羅地亞語': 'hr'
'捷克語': 'cs'
'丹麥語': 'da'
'荷蘭語': 'nl'
'英語': 'en'
'世界語': 'eo'
'愛沙尼亞語': 'et'
'芬蘭語': 'fi'
'法語': 'fr'
'弗里西語': 'fy'
'加利西亞語': 'gl'
'格魯吉亞語': 'ka'
'德語': 'de'
'希臘語': 'el'
'古吉拉特語': 'gu'
'海地克里奧爾語': 'ht'
'豪薩語': 'ha'
'夏威夷語': 'haw'
'希伯來語': 'he'
'印地語': 'hi'
'苗語': 'hmn'
'匈牙利語': 'hu'
'冰島語': 'is'
'伊博語': 'ig'
'印尼語': 'id'
'愛爾蘭語': 'ga'
'意大利語': 'it'
'日語': 'ja'
'爪哇語': 'jw'
'卡納達語': 'kn'
'哈薩克語': 'kk'
'高棉語': 'km'
'韓語': 'ko'
'庫爾德語': 'ku'
'吉爾吉斯語': 'ky'
'老撾語': 'lo'
'拉丁語': 'la'
'拉脫維亞語': 'lv'
'立陶宛語': 'lt'
'盧森堡語': 'lb'
'馬其頓語': 'mk'
'馬爾加什語': 'mg'
'馬來語': 'ms'
'馬拉雅拉姆語': 'ml'
'馬耳他語': 'mt'
'毛利語': 'mi'
'馬拉地語': 'mr'
'蒙古語': 'mn'
'緬甸語': 'my'
'尼泊爾語': 'ne'
'挪威語': 'no'
'尼楊扎語(齊切瓦語)': 'ny'
'普什圖語': 'ps'
'波斯語': 'fa'
'波蘭語': 'pl'
'葡萄牙語': 'pt'
'旁遮普語': 'pa'
'羅馬尼亞語': 'ro'
'俄語': 'ru'
'薩摩亞語': 'sm'
'蘇格蘭蓋爾語': 'gd'
'塞爾維亞語': 'sr'
'塞索托語': 'st'
'修納語': 'sn'
'信德語': 'sd'
'僧伽羅語': 'si'
'斯洛伐克語': 'sk'
'斯洛文尼亞語': 'sl'
'索馬里語': 'so'
'西班牙語': 'es'
'巽他語': 'su'
'斯瓦希里語': 'sw'
'瑞典語': 'sv'
'塔加洛語(菲律賓語)': 'tl'
'塔吉克語': 'tg'
'泰米爾語': 'ta'
'泰盧固語': 'te'
'泰語': 'th'
'土耳其語': 'tr'
'烏克蘭語': 'uk'
'烏爾都語': 'ur'
'烏茲別克語': 'uz'
'越南語': 'vi'
'威爾士語': 'cy'
'班圖語': 'xh'
'意第緒語': 'yi'
'約魯巴語': 'yo'
'祖魯語': 'zu'
'南非荷蘭語': 'af'
'阿爾巴尼亞語': 'sq'
'阿姆哈拉語': 'am'
'阿拉伯語': 'ar'
'亞美尼亞語': 'hy'
'阿塞拜疆語': 'az'
'巴斯克語': 'eu'
'白俄羅斯語': 'be'
'孟加拉語': 'bn'
'波斯尼亞語': 'bs'
'保加利亞語': 'bg'
'加泰羅尼亞語': 'ca'
'宿務(wù)語': 'ceb'
'中文(簡體)': 'zh'
'中文(繁體)': 'zh-TW'
'科西嘉語': 'co'
'克羅地亞語': 'hr'
'捷克語': 'cs'
'丹麥語': 'da'
'荷蘭語': 'nl'
'英語': 'en'
'世界語': 'eo'
'愛沙尼亞語': 'et'
'芬蘭語': 'fi'
'法語': 'fr'
'弗里西語': 'fy'
'加利西亞語': 'gl'
'格魯吉亞語': 'ka'
'德語': 'de'
'希臘語': 'el'
'古吉拉特語': 'gu'
'海地克里奧爾語': 'ht'
'豪薩語': 'ha'
'夏威夷語': 'haw'
'希伯來語': 'he'
'印地語': 'hi'
'苗語': 'hmn'
'匈牙利語': 'hu'
'冰島語': 'is'
'伊博語': 'ig'
'印尼語': 'id'
'愛爾蘭語': 'ga'
'意大利語': 'it'
'日語': 'ja'
'爪哇語': 'jw'
'卡納達語': 'kn'
'哈薩克語': 'kk'
'高棉語': 'km'
'韓語': 'ko'
'庫爾德語': 'ku'
'吉爾吉斯語': 'ky'
'老撾語': 'lo'
'拉丁語': 'la'
'拉脫維亞語': 'lv'
'立陶宛語': 'lt'
'盧森堡語': 'lb'
'馬其頓語': 'mk'
'馬爾加什語': 'mg'
'馬來語': 'ms'
'馬拉雅拉姆語': 'ml'
'馬耳他語': 'mt'
'毛利語': 'mi'
'馬拉地語': 'mr'
'蒙古語': 'mn'
'緬甸語': 'my'
'尼泊爾語': 'ne'
'挪威語': 'no'
'尼楊扎語(齊切瓦語)': 'ny'
'普什圖語': 'ps'
'波斯語': 'fa'
'波蘭語': 'pl'
'葡萄牙語': 'pt'
'旁遮普語': 'pa'
'羅馬尼亞語': 'ro'
'俄語': 'ru'
'薩摩亞語': 'sm'
'蘇格蘭蓋爾語': 'gd'
'塞爾維亞語': 'sr'
'塞索托語': 'st'
'修納語': 'sn'
'信德語': 'sd'
'僧伽羅語': 'si'
'斯洛伐克語': 'sk'
'斯洛文尼亞語': 'sl'
'索馬里語': 'so'
'西班牙語': 'es'
'巽他語': 'su'
'斯瓦希里語': 'sw'
'瑞典語': 'sv'
'塔加洛語(菲律賓語)': 'tl'
'塔吉克語': 'tg'
'泰米爾語': 'ta'
'泰盧固語': 'te'
'泰語': 'th'
'土耳其語': 'tr'
'烏克蘭語': 'uk'
'烏爾都語': 'ur'
'烏茲別克語': 'uz'
'越南語': 'vi'
'威爾士語': 'cy'
'班圖語': 'xh'
'意第緒語': 'yi'
'約魯巴語': 'yo'
'祖魯語': 'zu'
'''

四.總結(jié)

本次依然使用Tkinter做了一款翻譯器,但無論是界面還是功能都在上一版有了很大改進
1.支持txt文本文件導(dǎo)入翻譯
2.使用Combobox記錄當(dāng)前目標(biāo)語言
3.調(diào)用谷歌翻譯接口,翻譯準(zhǔn)確
4.自動識別源語言類型
5.加入鼠標(biāo)右鍵事件,粘貼更方便
GUI打包好放在了藍奏云,歡迎各位交流討論。

以上就是python 制作一個gui的翻譯工具的詳細內(nèi)容,更多關(guān)于python gui翻譯工具的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 基于Python制作個搶紅包的工具

    基于Python制作個搶紅包的工具

    快過年了,剛剛收到了兩個消息,一個好消息,一個壞消息。好消息就是微信群里有人要發(fā)紅包,壞消息是不一定能都搶到。所以本文就來用Python做一個搶紅包工具,需要的可以參考一下
    2023-01-01
  • Python ADF 單位根檢驗 如何查看結(jié)果的實現(xiàn)

    Python ADF 單位根檢驗 如何查看結(jié)果的實現(xiàn)

    這篇文章主要介紹了Python ADF 單位根檢驗 如何查看結(jié)果的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • python中遍歷文件的3個方法

    python中遍歷文件的3個方法

    這篇文章主要介紹了python中遍歷文件的3個方法,本文分別使用os.path.walk()、os.walk()、os.listdir()來實現(xiàn),需要的朋友可以參考下
    2014-09-09
  • python?gravis庫實現(xiàn)圖形數(shù)據(jù)可視化實例探索

    python?gravis庫實現(xiàn)圖形數(shù)據(jù)可視化實例探索

    這篇文章主要為大家介紹了python?gravis庫實現(xiàn)圖形數(shù)據(jù)可視化實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-02-02
  • Opencv實現(xiàn)摳圖背景圖替換功能

    Opencv實現(xiàn)摳圖背景圖替換功能

    這篇文章主要為大家詳細介紹了Opencv實現(xiàn)摳圖替換背景圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Pandas多個條件(AND,OR,NOT)中提取行

    Pandas多個條件(AND,OR,NOT)中提取行

    本文主要介紹了Pandas多個條件(AND,OR,NOT)中提取行,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • 深入學(xué)習(xí)python的yield和generator

    深入學(xué)習(xí)python的yield和generator

    這篇文章主要為大家詳細介紹了python的yield和generator,針對python的生成器和yield關(guān)鍵字進行深入學(xué)習(xí),感興趣的小伙伴們可以參考一下
    2016-03-03
  • Python深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)殘差塊

    Python深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)殘差塊

    這篇文章主要為大家介紹了Python深度學(xué)習(xí)中的神經(jīng)網(wǎng)絡(luò)殘差塊示例詳解有需要的 朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-10-10
  • 對命令行模式與python交互模式介紹

    對命令行模式與python交互模式介紹

    今天小編就為大家分享一篇對命令行模式與python交互模式介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 一文詳解Python中的subprocess模塊

    一文詳解Python中的subprocess模塊

    subprocess模塊是Python標(biāo)準(zhǔn)庫的一部分,提供了一個跨平臺的方法來生成新進程、連接其輸入/輸出/錯誤管道,并獲取其返回碼,本文小編將和大家一起深入理解Python中的subprocess模塊,感興趣的小伙伴跟著小編一起來看看吧
    2024-08-08

最新評論