用python开发文本翻译小软件

简介: 用python开发文本翻译小软件

思路介绍


我们在工作或者生活中有没有碰到这种情况,就是我们需要对内容进行翻译,平时的时候我们是一句一句的粘贴翻译后在粘贴回来,针对这种情况 ,我们可以试着可以用代码的方式帮我们进行执行。方便又快捷


首页,我们来设计软件的开发逻辑和思路,大致的思路是这样的



既然这样 ,那我们就按照我们前期的思路来写代码,分步骤来实现这些功能,

一,分行读取文本内容:


这里我将代码粘贴至下面,代码会做注释


nenr = input("输入txt文件所在位置:")  #将这里设置为用户自动输入
a=[]
with open(r"{}".format(nenr), "r") as f:
    for line in f.readlines(): #加入循环,分行读取文本内的全部内容
        line = line.strip('\n')  # 去掉列表中每一个元素的换行符,后续等内容翻译好后存入文本时需要再加上换行符,不然我们存入的数据会堆积在一起
        a.append(line) #将翻译的内容存入一个空的列表a
print(a) #打印a的内容


执行效果


       


ok这里我们看到,这几行代码已经讲数据给提取出来了,以一个列表的方式给取出来了,其中,文本里的每一行的内容就是列表里的一个元素,


二,将内容分行提取后进行翻译并整理好我们需要的格式


       我们将内容翻译出来后,这时就得想着,如何将内容给翻译好?这里我找到了一个第三方的翻译api,api的信息我就不粘贴了,后续有想要的可以私信我。我们看下如何实现这一步骤,代码如下:


import requests
nenr = input("输入txt文件所在位置:")  #将这里设置为用户自动输入
a=[]
with open(r"{}".format(nenr), "r") as f:
    for line in f.readlines(): #加入循环,分行读取文本内的全部内容
        line = line.strip('\n')  # 去掉列表中每一个元素的换行符,后续等内容翻译好后存入文本时需要再加上换行符,不然我们存入的数据会堆积在一起
        a.append(line) #将翻译的内容存入一个空的列表a
b=[]  #定义一个空列表b,这个列表是方便我们后续存入翻译后的内容
for x in a:  #这里我们使用循环,将存入数据的列表a给分步骤翻译
    a_1 = requests.get(url="http://fanyi.youdao.com/translate?&doctype=json&type=AUTO&i=""{}".format(x))  #通过循环将列表的数据逐个翻译
    b.append(a_1.json()["translateResult"][0][0]["tgt"] + "\n") #这里将翻译后的数据给提取出来,然后将这个数据存入空列表b中,这里记得再存入的时候加上划行符“\n”
print(b) #查看我们翻译后的内容


ok,我们来看下执行效果



我们看到,这里我们已经将内容给翻译好了,既然翻译好了的话,我们就可以把翻译的内容给替换掉文本里的内容了


三,将翻译后的数据替换掉之前的数据


       既然翻译好了,这时候我们就应该把翻译后的数据替换掉之前的数据才行,不让我们这样翻译和直接手动逐条翻译有什么区别咧


import requests
nenr = input("输入txt文件所在位置:")  #将这里设置为用户自动输入
a=[]
with open(r"{}".format(nenr), "r") as f:
    for line in f.readlines(): #加入循环,分行读取文本内的全部内容
        line = line.strip('\n')  # 去掉列表中每一个元素的换行符,后续等内容翻译好后存入文本时需要再加上换行符,不然我们存入的数据会堆积在一起
        a.append(line) #将翻译的内容存入一个空的列表a
b=[]  #定义一个空列表b,这个列表是方便我们后续存入翻译后的内容
for x in a:  #这里我们使用循环,将存入数据的列表a给分步骤翻译
    a_1 = requests.get(url="http://fanyi.youdao.com/translate?&doctype=json&type=AUTO&i=""{}".format(x))  #通过循环将列表的数据逐个翻译
    b.append(a_1.json()["translateResult"][0][0]["tgt"] + "\n") #这里将翻译后的数据给提取出来,然后将这个数据存入空列表b中,这里记得再存入的时候加上划行符“\n”
print(b) #查看我们翻译后的内容
file_handle = open(r"{}".format(nenr), mode='w')
file_handle.writelines(b)  #将集合b存入文本里
file_handle.close()  #数据存入后关闭文本


我们来看下执行后的效果



不错不错,既然翻译好了 我们何不再加上其他的一些优化加强咧,比如 判断是否选择的是txt文件,或者是当txt文件是否存在 或者 我们可以把代码给打包成其他的一些内容,既然有思路了,我们就开始吧,


四,判断用户输入的是否是txt文件


       这里我们要想判断用户输入的是不是txt文件时,我们可以直接判断后缀,如果用户输入的内容的末尾没有带上 .txt 这时,我们是否就可以判断用户输入的不是txt文件。有思路就通过代码实现,代码如下:


import os
import requests
nenr = input("输入txt文件所在位置:")  #将这里设置为用户自动输入
a=[]
accs = os.path.splitext(r"{}".format(nenr))[1] in ['.txt']  #这行代码是将判断用户输入的内容末尾是否是.txt 如果是,则返回true
if accs == True:  #这里我们加入判断,如果是返回的是true,则执行正常的代码:
    with open(r"{}".format(nenr), "r") as f:
        for line in f.readlines(): #加入循环,分行读取文本内的全部内容
            line = line.strip('\n')  # 去掉列表中每一个元素的换行符,后续等内容翻译好后存入文本时需要再加上换行符,不然我们存入的数据会堆积在一起
            a.append(line) #将翻译的内容存入一个空的列表a
    b=[]  #定义一个空列表b,这个列表是方便我们后续存入翻译后的内容
    for x in a:  #这里我们使用循环,将存入数据的列表a给分步骤翻译
        a_1 = requests.get(url="http://fanyi.youdao.com/translate?&doctype=json&type=AUTO&i=""{}".format(x))  #通过循环将列表的数据逐个翻译
        b.append(a_1.json()["translateResult"][0][0]["tgt"] + "\n") #这里将翻译后的数据给提取出来,然后将这个数据存入空列表b中,这里记得再存入的时候加上划行符“\n”
    print(b) #查看我们翻译后的内容
    file_handle = open(r"{}".format(nenr), mode='w')
    file_handle.writelines(b)  #将集合b存入文本里
    file_handle.close()  #数据存入后关闭文本
else:
    print("请输入正确的文件类型") #当用户输入的内容不是txt文件时,则给出用户提示


我们来看下执行后的效果:



这里我们发现一个问题,当用户执行后,如果文件类型不正确就直接停止掉了,这样用户就需要重输入,对用户很不友好,咋办,我们加入循环,当用户执行成功后,代码翻译后,结束循环,如果文件类型不正确,那就重新循环,顺便,再给用户执行成功时加入一个提示


五,加入循环,提升用户体验


        这里我们加入循环操作,提示用户体检,然后再给执行成功后加上提示,代码如下


import os
import requests
while True: #加入死循环,当翻译成功后结束循环,其他情况下一直循环
    nenr = input("输入txt文件所在位置:")  #将这里设置为用户自动输入
    a=[]
    b = [] #定义一个空列表b,这个列表是方便我们后续存入翻译后的内容
    accs = os.path.splitext(r"{}".format(nenr))[1] in ['.txt']  #这行代码是将判断用户输入的内容末尾是否是.txt 如果是,则返回true
    if accs == True:  #这里我们加入判断,如果是返回的是true,则执行正常的代码:
        with open(r"{}".format(nenr), "r") as f:
            for line in f.readlines(): #加入循环,分行读取文本内的全部内容
                line = line.strip('\n')  # 去掉列表中每一个元素的换行符,后续等内容翻译好后存入文本时需要再加上换行符,不然我们存入的数据会堆积在一起
                a.append(line) #将翻译的内容存入一个空的列表a
        for x in a:  #这里我们使用循环,将存入数据的列表a给分步骤翻译
            a_1 = requests.get(url="http://fanyi.youdao.com/translate?&doctype=json&type=AUTO&i=""{}".format(x))  #通过循环将列表的数据逐个翻译
            b.append(a_1.json()["translateResult"][0][0]["tgt"] + "\n") #这里将翻译后的数据给提取出来,然后将这个数据存入空列表b中,这里记得再存入的时候加上划行符“\n”
        print(b) #查看我们翻译后的内容
        file_handle = open(r"{}".format(nenr), mode='w')
        file_handle.writelines(b)  #将集合b存入文本里
        file_handle.close()  #数据存入后关闭文本
        print("翻译成功,请至文件夹内查看")  #翻译成功后提示
        break #翻译成功后结束循环
    else:
        print("请输入正确的文件类型") #当用户输入的内容不是txt文件时,则给出用户提示


执行效果如下:



这里我们看到,执行效果不错,既然这样的话,我们何不给代码打过包,提升软件的实用性,让其他电脑上没装python的同事也能使用?


六,打包


这里我们使用的是python的打包模块pyinstaller,我太饿了,打包模块的使用方法我就不多说了,后续有啥问题或者其他情况可以私聊或者评论,我都会回复


打包代码:pyinstaller -F -i acc.ico abcc.py


打包后的效果



执行的效果:



相关文章
|
23天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
【10月更文挑战第12天】本文探讨了Python开发中性能优化和代码审查的重要性,介绍了选择合适数据结构、使用生成器、避免全局变量等性能优化技巧,以及遵守编码规范、使用静态代码分析工具、编写单元测试等代码审查方法,旨在帮助开发者提升开发效率和代码质量。
31 5
|
29天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
【10月更文挑战第6天】本文探讨了性能优化和代码审查在Python开发中的重要性,提供了选择合适数据结构、使用生成器、避免全局变量等性能优化技巧,以及遵守编码规范、使用静态代码分析工具、编写单元测试等代码审查方法,旨在帮助开发者提升开发效率和代码质量。
53 5
|
7天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
81 44
|
3天前
|
JSON 安全 API
如何使用Python开发API接口?
在现代软件开发中,API(应用程序编程接口)用于不同软件组件之间的通信和数据交换,实现系统互操作性。Python因其简单易用和强大功能,成为开发API的热门选择。本文详细介绍了Python开发API的基础知识、优势、实现方式(如Flask和Django框架)、实战示例及注意事项,帮助读者掌握高效、安全的API开发技巧。
20 3
如何使用Python开发API接口?
|
1天前
|
数据采集 存储 JSON
Python爬虫开发中的分析与方案制定
Python爬虫开发中的分析与方案制定
|
3天前
|
机器学习/深度学习 自然语言处理 API
如何使用阿里云的语音合成服务(TTS)将文本转换为语音?本文详细介绍了从注册账号、获取密钥到编写Python代码调用TTS服务的全过程
如何使用阿里云的语音合成服务(TTS)将文本转换为语音?本文详细介绍了从注册账号、获取密钥到编写Python代码调用TTS服务的全过程。通过简单的代码示例,展示如何将文本转换为自然流畅的语音,适用于有声阅读、智能客服等场景。
20 3
|
8天前
|
数据可视化 开发者 Python
Python GUI开发:Tkinter与PyQt的实战应用与对比分析
【10月更文挑战第26天】本文介绍了Python中两种常用的GUI工具包——Tkinter和PyQt。Tkinter内置于Python标准库,适合初学者快速上手,提供基本的GUI组件和方法。PyQt基于Qt库,功能强大且灵活,适用于创建复杂的GUI应用程序。通过实战示例和对比分析,帮助开发者选择合适的工具包以满足项目需求。
40 7
|
11天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
探讨了Python开发中性能优化和代码审查的重要性,介绍了选择合适数据结构、使用生成器、避免全局变量等性能优化技巧,以及遵守编码规范、使用静态代码分析工具、编写单元测试等代码审查方法,旨在帮助开发者提升开发效率和代码质量。
31 8
|
7天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
性能优化与代码审查:提升Python开发效率
17 1
|
8天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
26 2

热门文章

最新文章