python 实现翻译功能

二、使用步骤

1.翻译

代码如下(示例):

def bdfanyi():
    import requests
    import json
    headers={
        'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36
    }
    post_url = 'https://fanyi.baidu.com/sug'

    # post请求处理
    word = input('enter a word:')
    data = {
        'kw':word
    }
    response = requests.post(url=post_url,data=data,headers=headers)

    # 获取响应数据,由于响应数据格式为json,而json()返回的是obj,当且仅当确认响应数据类型为json,才可以使用json()
    dic_obj = response.json()
    dict_tiqu(dic_obj)
        
    filename= word + '.json'
    # fp = open(fileName,'w',encoding='utf-8')
    fp=mkdoc('输入你的文件夹',filename)
    json.dump(dic_obj,fp=fp,ensure_ascii=False)
def tiqu(a):
    import re
    b=re.findall('\'k\':\s\'(\w+)\'',a)
    c=re.findall('\'v\':\s\'(\w+\.\s.*?)\'|\'(\[.名\]\s.*?)\'}',a)#\[.名\]\s.*?\'} and \'v\':\s\'(\w+\.\s.*?)\'
    # print(b,c)
    return b,c
def meanbug(mean):#去除列表元组中空值
    l=[]
    for i in range(0,len(mean)-1):
        if mean[i][0]:
            l.append(str(mean[i][0]))
        else:
            l.append(str(mean[i][1]))
    return l
def mkdoc(a,b):
    import os
    if not a:
        fp = open(b, "w") 
        return fp
        # 先创建.txt文件所在的文件夹
    elif not os.path.exists(a):
        os.makedirs(a)
# 创建test.txt文件
        fp = open(a+'/'+b, "w")
        return fp
    elif a:
        fp = open(a+'/'+b, "w")
        return fp
def dict_tiqu(a):#a为字典
    for i in range(len(a['data'])):
        b=a['data'][i]
        print("单词:%s\t意思:%s" % (b['k'],b['v']))

while true:
    bdfanyi()

总结

输入单词,返回相关翻译以及自动保存json在指定位置

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 PDF 的翻译,可以使用 Python 中的 PyPDF2 库来解析 PDF 文件,再结合 Google Translate API 实现翻译功能。具体步骤如下: 1. 安装 PyPDF2 库和 Google Cloud Translate API。 2. 用 PyPDF2 库读取 PDF 文件的每一页内容,将文字提取出来。 3. 将提取出来的文字传给 Google Translate API 进行翻译。 4. 将翻译后的文本重新写回 PDF 文件中对应的位置。 下面是一个简单的示例代码: ``` python import PyPDF2 from google.cloud import translate_v2 as translate # 读取 PDF 文件 pdf_file = open('example.pdf', 'rb') pdf_reader = PyPDF2.PdfFileReader(pdf_file) # 创建 Google Translate API 客户端 translate_client = translate.Client() # 循环遍历 PDF 每一页 for page_index in range(pdf_reader.getNumPages()): # 获取当前页的文本 page = pdf_reader.getPage(page_index) text = page.extractText() # 翻译文本 result = translate_client.translate(text, target_language='en') # 将翻译后的文本重新写回 PDF 文件中 page.mergeTranslatedPage(result['input'], result['translatedText']) # 保存修改后的 PDF 文件 pdf_writer = PyPDF2.PdfFileWriter() for page_index in range(pdf_reader.getNumPages()): pdf_writer.addPage(pdf_reader.getPage(page_index)) with open('translated.pdf', 'wb') as output_file: pdf_writer.write(output_file) # 关闭文件和 API 客户端 pdf_file.close() ``` 注意,在使用 Google Translate API 时需要提供认证信息,可以通过设置环境变量或者使用密钥文件来进行认证。具体可以参考 Google Cloud 文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值