利用python制作点读翻译软件(基于google api)

利用python制作点读翻译软件(基于google api)

        摘要:实现点读功能,自动朗读翻译整段。
        完整代码git地址:https://github.com/luoqingyu/Read-translation-machine
程序思路:首先是获取要翻译和朗读的英文数据来源,这里假定我们正在阅读PDF,遇到一段有困难的话,我想要实现的是使用鼠标左键将句子整体选上实现朗读翻译
1.获取需要翻译的内容:选中需要翻译的句子,ctrl+c复制到剪切板上,利用python读取剪切板内容,获取带翻译数据。
2.朗读:获取到待翻译的数据后,调用pyttsx语言库对文本进行朗读。
3.翻译:获取剪切板内容后,调用googletrans库获取翻译结果。
4.界面显示:主要是显示翻译内容,使用tkinter库绘制界面。



实现效果:





分模块实现
1.获取截切板内容朗读   readCopy.py
#-*- coding: utf-8 -*-         
import  win32clipboard 
import  win32clipboard as wc                #用以获取剪切板内容的支持库
import  win32con
import pyttsx                               #语言支持库
import chardet                                
import time

def speakInit():                     
    engine = pyttsx.init()                  #初始化语音引起
    rate = engine.getProperty('rate')       #获取初始语速  初始为200我觉得有点快,改成了120
    engine.setProperty('rate', 120)         #修改初始语速
    voices = engine.getProperty('voices')   #选择发音人物,听了所有人物,觉得这个id的小姐姐声音好听
    engine.setProperty('voice', "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Speech\Voices\Tokens\TTS_MS_EN-US_ZIRA_11.0")
    return  engine                          #返回一个初始化好的语言借口

def getCopyText():                          #获取剪切板内容
    wc.OpenClipboard()
    copy_text= wc.GetClipboardData(win32con.CF_TEXT) 
    wc.CloseClipboard()
    return  copy_text



old_text = "hi"                             #剪切板内容更新了才进行朗读    

if __name__ == "__main__":                  #测试函数
    old_text = "hi"
    engine = speakInit()                    #初始化语言接口
    while (1):

        time.sleep(1)                            #延时1s防止频繁访问剪切板
        print  chardet.detect(getCopyText())     #打印剪切板内容

        if (getCopyText() != old_text):          #如果剪切板更新了

            try:
                engine.say(getCopyText())
                time.sleep(1)
                engine.say(getCopyText())
                engine.runAndWait()
                old_text = getCopyText()
            except:
                pass

2.调用google翻译api    testtestGoogletrans.py
#-*- coding: utf-8 -*-                    
from googletrans import Translator               #倒入google翻译包


def translate(sendwords):                        #编写中文翻译函数
    translator = Translator()
    return (translator.translate(sendwords,dest='zh-CN').text)



if __name__ == "__main__":                        #测试函数
    print ('20')
    words= "We trained a large, deep convolutional neural network"
    translate(words)

3.编写界面和主函数    主函数使用了以上两个文件,请保持这些文件在一个文件夹中
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import time
import  tkinter as tk
from googletrans import Translator
import  readCopy
import  testtestGoogletrans                                        #倒入所需库

old_text = ''
new_text = 'hi'
engine = readCopy.speakInit() 
def update_timeText():                                            #差看剪切板文字是否更新
    global  old_text
    global  new_text
    new_text = readCopy.getCopyText()

    print (new_text+ '+')                                         #显示内容方便调试
    print  (old_text+'-')
    if (new_text != old_text):

        try:

            words = new_text
            result = testtestGoogletrans.translate(words)
            Label2.configure(text=result)
            Label2.pack

            old_text =new_text
            window.after(1000, update_timeText)                  #程序精髓,1S后更新界面
            return   read_text()
        except:
            window.after(1000, update_timeText)                  #有异常也要更新
    else:
        window.after(1000, update_timeText)


def read_text():                                     #读剪切板内容
    global  engine
    engine.say(new_text)

    engine.runAndWait()




def init():                                         #界面初始化
    window = tk.Tk()
    Button1=tk.Button(window, text='再次朗读',  command=lambda:read_text())
    Button1.place(x=350,y=20)
    window.title('daydayup点读机')
    window.geometry('400x200')
    Label1=tk.Label(window,text='结果')
    Label1.place(x=10,y=10)
    Label2=tk.Label(window,text='*******', font = ("Arial, 14"),wraplength=300)
    Label2.place(x=20,y=40)

    return  Label2 ,window






if __name__ == "__main__":                   

    Label2,window=init()
    engine = readCopy.speakInit()
    new_text =  readCopy.getCopyText()

    try:
        words = new_text
        result=testtestGoogletrans.translate(words)
        Label2.configure(text=result)
        Label2.place(x=20, y=40)
        Label2.pack()
        update_timeText()
        window.wm_attributes('-topmost', 1)
        window.mainloop()
    except:
        pass


整理完成
 
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信版本:6.3.30 IOS版本:IOS_10.0.2 微信开发调试工具:v0.10.102800 操作系统:Win7 开发/调试:iPhone6S真机/微信工具预览,PHPstorm编码 使用说明 由于微信安全域名的限制,如果你填了自己的APPID,所有请求都会失败 无APPID的情况下,使用微信登录会存在问题,请使用手机号登录 目前是测试版本,故未接入短信平台,所以手机是收不到验证码的,直接点获取验证码就已经填上了 如需在微信中体验完整功能,请联系文末的邮箱,注明理由和微信号申请体验权限 使用过程遇到的坑丶记录 背景图不生效,改用image或者Base64 执行POST请求异常,将data中的JSON对象格式化为from序列 页面切换的参数接收异常,在onload方法中,默认的参数即使上一页面传过来的Object参数 在使用data-readingItem的时候,微信解析为dataset的时候会转成小写 多页面的时候,在app.json中重复配置,会编译失败 直接使用 this.data.XXX = XXX 赋值的时候,数据是不会同步输出到VM即WXML中的,必须使用其setData方法 循环加载JSON数据集合时,如果其中有项是null,在开发工具中加载正常,但是在手机中浏览时显示空白页,并且调试时没有错误信息,所以需要对可能为null的数据进行判断 PS:由于有预处理,所以没有遇到这个问题 针对swiper控件,设置min-height不生效,必须设置height,同时swiper-item的间隙也有坑,项目中有实践 使用uploadFile-formData传递参数的时候,formData是个三项的JSON,PHP通过$_REQUEST尽然只能接到最后一个参数 PS:怀疑是微信的坑,后来使用的是将其以GET方式提交,才正常接到 在使用for循环的时候,用的是立即执行的闭包函数,但是PHP端接到的三个请求的time竟然是一样的,这直接导致了文件获取的异常, 目前未找到真实原因,是本人对for循环理解太浅?后通过额外加参数解决 微信录制的音频格式为.silk格式,具体可以Google,强大的ffmpeg都没法直接解码,最后使用了GitHub上的一个开源Decoder库, 解码成功转成了MP3,感谢作者,地址:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值