无聊的时候刷抖音发现了一个好玩的,论文文献翻译器,可以实时的翻译内容,具体是这么个功能,看着还不错。用python来实现一下类似功能。

软件实现:
软件通过实时检测剪切板的内容来实现实时翻译
用的是百度基础翻译api,当然可以注册有道云的翻译api(翻译效果不错),不过只提供50块钱的翻译量(也不少。。。),我们加上tk可视化库来完成软件的大体功能。

  1. 注册百度账号
  2. 注册为百度翻译者个人用户
  3. 下载Python-demo
  4. 导入个人密钥
  5. 动态获取剪切板内容
  6. 实现翻译功能

百度api注册网址:http://fanyi-api.baidu.com/api/trans/product/prodinfo

ai python 翻译 python做翻译软件_tkinter


ai python 翻译 python做翻译软件_tkinter_02


ai python 翻译 python做翻译软件_在线翻译_03


点击总览 下方有申请信息 里面有app id 和密钥

然后上代码:

import http.client
import hashlib
import urllib
import random
import json
from tkinter import *
import win32clipboard,time
import threading
#百度翻译api
def translate(fromLang,toLang,q):
    appid = '**********'  # 填写你的appid
    secretKey = '**********'  # 填写你的密钥
    httpClient = None
    myurl = '/api/trans/vip/translate'
    fromLang = fromLang   #原文语种
    toLang = toLang   #译文语种
    salt = random.randint(32768, 65536)
    q= q
    sign = appid + q + str(salt) + secretKey
    sign = hashlib.md5(sign.encode()).hexdigest()
    myurl = myurl + '?appid=' + appid + '&q=' + urllib.parse.quote(q) + '&from=' + fromLang + '&to=' + toLang + '&salt=' + str(
    salt) + '&sign=' + sign
    try:
        httpClient = http.client.HTTPConnection('api.fanyi.baidu.com')
        httpClient.request('GET', myurl)
        # response是HTTPResponse对象
        response = httpClient.getresponse()
        result_all = response.read().decode("utf-8")
        result = json.loads(result_all)
        return result['trans_result'][0]['dst']
    except Exception as e:
        print (e)
    finally:
        if httpClient:
            httpClient.close()

获取和设置剪切板内容:

#获取剪切板输入
def clipboard_get():
    win32clipboard.OpenClipboard()
    data = win32clipboard.GetClipboardData()
    win32clipboard.CloseClipboard()
    return data
#设置剪切板输入
def clipboard_set(data):
    win32clipboard.OpenClipboard()
    win32clipboard.EmptyClipboard()
    win32clipboard.SetClipboardData(win32clipboard.CF_UNICODETEXT, data)
    win32clipboard.CloseClipboard()

主程序:

#主函数
def newmain(fromlang,to):
    '''
    fromlang:翻译源
    to:翻译目标
    '''
    while 1:
        data=clipboard_get()
        if flag !='out':
            if data !='404':
                if data !='':
                    target=translate(fromlang,to,data)
                    fromres.set(data)
                    result.set(target)
                    clipboard_set('404')
                else:
                    #print('不可为空')
                    pass
            else:
                #print('暂无数据')
                time.sleep(2)
        else:
            print('退出')
            break

全部代码:

#百度通用翻译API,不包含词典、tts语音合成等资源,如有相关需求请联系translate_api@baidu.com
# coding=utf-8

import http.client
import hashlib
import urllib
import random
import json
from tkinter import *
import win32clipboard,time
import threading
#百度翻译api
def translate(fromLang,toLang,q):
    appid = '******'  # 填写你的appid
    secretKey = '*****'  # 填写你的密钥
    httpClient = None
    myurl = '/api/trans/vip/translate'
    fromLang = fromLang   #原文语种
    toLang = toLang   #译文语种
    salt = random.randint(32768, 65536)
    q= q
    sign = appid + q + str(salt) + secretKey
    sign = hashlib.md5(sign.encode()).hexdigest()
    myurl = myurl + '?appid=' + appid + '&q=' + urllib.parse.quote(q) + '&from=' + fromLang + '&to=' + toLang + '&salt=' + str(
    salt) + '&sign=' + sign
    try:
        httpClient = http.client.HTTPConnection('api.fanyi.baidu.com')
        httpClient.request('GET', myurl)
        # response是HTTPResponse对象
        response = httpClient.getresponse()
        result_all = response.read().decode("utf-8")
        result = json.loads(result_all)
        return result['trans_result'][0]['dst']
    except Exception as e:
        print (e)
    finally:
        if httpClient:
            httpClient.close()
#获取剪切板输入
def clipboard_get():
    win32clipboard.OpenClipboard()
    data = win32clipboard.GetClipboardData()
    win32clipboard.CloseClipboard()
    return data
#设置剪切板输入
def clipboard_set(data):
    """设置剪贴板数据"""
    win32clipboard.OpenClipboard()
    win32clipboard.EmptyClipboard()
    win32clipboard.SetClipboardData(win32clipboard.CF_UNICODETEXT, data)
    win32clipboard.CloseClipboard()
#主函数
def newmain(fromlang,to):
    '''
    fromlang:翻译源
    to:翻译目标
    '''
    while 1:
    
        data=clipboard_get()
        if flag !='out':
            if data !='404':
                if data !='':
                    target=translate(fromlang,to,data)
                    fromres.set(data)
                    result.set(target)
                    clipboard_set('404')
                else:
                    #print('不可为空')
                    pass
            else:
                #print('暂无数据')
                time.sleep(2)
        else:
            print('退出')
            break
#汉译英 可调整翻译语言 参见百度api文档
def thread_zhToEn():
    t1=threading.Thread(target=newmain,args=('zh','en'))
    t1.start()
#英翻汉
def thread_EhToZn():
    t2=threading.Thread(target=newmain,args=('en','zh'))
    t2.start()
if __name__ == '__main__':
'''
flag:由于threading没有提供杀死线程,所以设置一个标识来结束函数
为防止tk卡死需要引入线程来完成翻译功能
'''
    flag='1'
    app=Tk()
    app.title('翻译程序 author:liubingzhe')
    app.geometry('800x600')
    fromres=StringVar()
    result=StringVar()
    button_run=Button(app,text='汉译英',command=thread_zhToEn,width=800).pack()
    button_run=Button(app,text='英译汉',command=thread_EhToZn,width=800).pack()
    Label=Label(app,text='请退出后切换翻译模式').pack()
    w = Message(app,textvariable=fromres,aspect=200,font=('微软雅黑','11')).pack()
    w1 = Message(app,textvariable=result,aspect=200,font=('微软雅黑','11')).pack()
    app.mainloop()
    flag='out'

通过Ctrl-C复制内容,软件每隔两秒获取一次剪切板内容,通过调用百度翻译api来实现动态翻译,点击上方汉译英或英译汉来开启功能。

每隔两秒是为了防止剪切板接口由于频繁读取报错,不会影响软件体验。

ai python 翻译 python做翻译软件_ai python 翻译_04


可以调整message的aspect参数来调整显示的样式

当然也可以设定为固定值width来更好的优化显示效果

没有怎么优化,基本就是这个样子了

w = Message(app,textvariable=fromres,width=700,font=('微软雅黑','11')).pack()
 w1 = Message(app,textvariable=result,width=700,font=('微软雅黑','11')).pack()

ai python 翻译 python做翻译软件_gui_05


将其用pyinstaller打包做成桌面软件就可以啦.