用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


打包后的效果



执行的效果:



相关文章
|
2月前
|
存储 数据库连接 API
Python环境变量在开发和运行Python应用程序时起着重要的作用
Python环境变量在开发和运行Python应用程序时起着重要的作用
105 15
|
11天前
|
前端开发 搜索推荐 编译器
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
【01】python开发之实例开发讲解-如何获取影视网站中经过保护后的视频-用python如何下载无法下载的视频资源含m3u8-python插件之dlp-举例几种-详解优雅草央千澈
|
22天前
|
IDE 测试技术 开发工具
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
在Python开发中,调试是提升效率的关键技能。本文总结了10个实用的调试方法,涵盖内置调试器pdb、breakpoint()函数、断言机制、logging模块、列表推导式优化、IPython调试、警告机制、IDE调试工具、inspect模块和单元测试框架的应用。通过这些技巧,开发者可以更高效地定位和解决问题,提高代码质量。
157 8
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
|
1天前
|
人工智能 Python
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
|
22天前
|
存储 运维 监控
探索局域网电脑监控软件:Python算法与数据结构的巧妙结合
在数字化时代,局域网电脑监控软件成为企业管理和IT运维的重要工具,确保数据安全和网络稳定。本文探讨其背后的关键技术——Python中的算法与数据结构,如字典用于高效存储设备信息,以及数据收集、异常检测和聚合算法提升监控效率。通过Python代码示例,展示了如何实现基本监控功能,帮助读者理解其工作原理并激发技术兴趣。
55 20
|
11天前
|
人工智能 编译器 Python
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
|
2月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
222 45
|
1月前
|
存储 API 数据库
使用Python开发获取商品销量详情API接口
本文介绍了使用Python开发获取商品销量详情的API接口方法,涵盖API接口概述、技术选型(Flask与FastAPI)、环境准备、API接口创建及调用淘宝开放平台API等内容。通过示例代码,详细说明了如何构建和调用API,以及开发过程中需要注意的事项,如数据库连接、API权限、错误处理、安全性和性能优化等。
104 5
|
2月前
|
JSON 安全 API
如何使用Python开发API接口?
在现代软件开发中,API(应用程序编程接口)用于不同软件组件之间的通信和数据交换,实现系统互操作性。Python因其简单易用和强大功能,成为开发API的热门选择。本文详细介绍了Python开发API的基础知识、优势、实现方式(如Flask和Django框架)、实战示例及注意事项,帮助读者掌握高效、安全的API开发技巧。
322 3
如何使用Python开发API接口?
|
20天前
|
存储 缓存 算法
探索企业文件管理软件:Python中的哈希表算法应用
企业文件管理软件依赖哈希表实现高效的数据管理和安全保障。哈希表通过键值映射,提供平均O(1)时间复杂度的快速访问,适用于海量文件处理。在Python中,字典类型基于哈希表实现,可用于管理文件元数据、缓存机制、版本控制及快速搜索等功能,极大提升工作效率和数据安全性。
53 0