用python做個翻譯小軟件吧~

Python 2.7.13
IDE Pycharm 5.0.3

macOS 10.12.1


前言

花了一點時間,半抄半寫半修改的寫了第一個能用的python小程序,作用是在IDE端模擬有道詞典的訪問,效果如下圖所示,不足之處在于,當輸入的中英文字符串超過一定數量,會拋出中間代碼,新手并不知道怎么處理,望知道的不吝賜教


初階:交互界面

首先在jupyter或者pycharm中進行交互的操作,核心語句是使用raw_input捕獲系統輸入

效果圖

效果圖

代碼

# -*- coding: utf-8 -*-

import urllib2
import urllib  # python2.7才需要兩個urllib
import json
while True:
    content = raw_input("請輸入需要翻譯的內容:")  # 系統捕獲輸入,就是命令框會彈出提示,需要你進行手動輸入
    if content == 'q':  # 輸入q退出while循環
        break
    
    url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
    data = {}  # 構造data,里面構造參數傳入
    data['type'] = 'AUTO'
    data['i']=content
    data['doctype'] = 'json' 
    data['xmlVersion'] = '1.8'
    data['keyfrom'] = 'fanyi.web'
    data['ue'] = 'UTF-8'
    data['action'] = 'FY_BY_ENTER'
    data['typoResult'] = 'true'
    
    data = urllib.urlencode(data).encode('utf-8')  # 將構造的data編碼
    req = urllib2.Request(url)  # 向瀏覽器發出請求
    response = urllib2.urlopen(req, data)   # 帶參請求,返回執行結果
    html = response.read().decode('utf-8')
    # print(html)  # 可以取消print的注釋,查看其中效果,這邊獲取的結果是進行解析

    target = json.loads(html)   # 以json形式載入獲取到的html字符串
    
    print "翻譯的內容是:"+target['translateResult'][0][0]['tgt'].encode('utf-8')
    

# 請輸入需要翻譯的內容:test
# 翻譯的內容是:測試
# 請輸入需要翻譯的內容:測試
# 翻譯的內容是:test
# 請輸入需要翻譯的內容:q

注意:這里的data字典中的數據根據實際網頁中數據為準,可能會不一樣,具體操作,點擊審查元素。或見小甲魚54講。


進階:做成gui

離實用還差那么兩步,第一步是先做成GUI

可以參考以前我寫的: Python基于Tkinter的二輸入規則器(乞丐版)

界面效果

這里寫圖片描述

代碼

# -*- coding: utf-8 -*-
'''
Author:哈士奇說喵
UDate: 2016.7.21
'''
from Tkinter import *
import difflib
import urllib2
import urllib  # python2.7才需要兩個urllib
import json
  

# ----------------------主框架部分----------------------

root = Tk()
root.title('翻譯GUI&beta1')
root.geometry()
Label_root=Label(root)

#-----------------------定義規則------------------------

def translate(content):
    
    url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
    data = {}  # 構造data,里面構造參數傳入
    data['type'] = 'AUTO'
    data['i']=content
    data['doctype'] = 'json' 
    data['xmlVersion'] = '1.8'
    data['keyfrom'] = 'fanyi.web'
    data['ue'] = 'UTF-8'
    data['action'] = 'FY_BY_ENTER'
    data['typoResult'] = 'true'
    
    data = urllib.urlencode(data).encode('utf-8')  # 將構造的data編碼
    req = urllib2.Request(url)  # 向瀏覽器發出請求
    response = urllib2.urlopen(req, data)   # 帶參請求,返回執行結果
    html = response.read().decode('utf-8')
    # print(html)  # 可以取消print的注釋,查看其中效果,這邊獲取的結果是進行解析

    target = json.loads(html)   # 以json形式載入獲取到的html字符串
    
    #print u"翻譯的內容是:"+target['translateResult'][0][0]['tgt']
    return target['translateResult'][0][0]['tgt'].encode('utf-8')
  


#還可以繼續增加規則函數,只要是兩輸入的參數都可以
#----------------------觸發函數-----------------------

def Answ():# 規則函數

    Ans.insert(END,"翻譯 %s: "%var_first.get().encode('utf-8') + translate(var_first.get().encode('utf-8')))
    
def Clea():#清空函數
    input_num_first.delete(0,END)#這里entry的delect用0
    Ans.delete(0,END)#text中的用0.0


#----------------------輸入選擇框架--------------------
frame_input = Frame(root)
Label_input=Label(frame_input, text='請輸入需要翻譯的內容', font=('',15))
var_first = StringVar()
input_num_first = Entry(frame_input, textvariable=var_first)


#---------------------計算結果框架---------------------
frame_output = Frame(root)
Label_output=Label(frame_output, font=('',15))
Ans = Listbox(frame_output, height=5,width=30) #text也可以,Listbox好處在于換行


#-----------------------Button-----------------------

calc = Button(frame_output,text='翻譯', command=Answ)
cle = Button(frame_output,text='清空', command=Clea)



Label_root.pack(side=TOP)
frame_input.pack(side=TOP)
Label_input.pack(side=LEFT)

input_num_first.pack(side=LEFT)

frame_output.pack(side=TOP)
Label_output.pack(side=LEFT)
calc.pack(side=LEFT)
cle.pack(side=LEFT)
Ans.pack(side=LEFT)

#-------------------root.mainloop()------------------

root.mainloop()

高階:發布應用

如何在小伙伴面前裝B才是我學習的動力,哈哈哈
教程更新如下:將自己的python程序打包成.exe/.app(秀同學一臉吶)


Pay Attention

  • python3的用戶注意url包的使用和python2是有區別的,請根據實際需求自行百度
  • Python如果操作頻率太快或者網頁限制機器人對此的訪問,則需要修改head了,修改代碼后.當然每個電腦的user都不一樣,具體去審查元素查看。
req = urllib2.Request(url) # 生成對象
# 添加如下一行代碼;
req.add_header('User-Agent','Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36'),這樣就可以偽裝成人類啦
  • 當然也可以添加延時模塊, 即可限定訪問時間。
import time  #添加延時模塊
time.sleep(1)#休息1秒鐘再進行操作

更新

  • 2016.6.14 初次撰寫
  • 2017.7.22 重新排版,增加tkinter等
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • # Python 資源大全中文版 我想很多程序員應該記得 GitHub 上有一個 Awesome - XXX 系列...
    aimaile閱讀 26,568評論 6 427
  • 環境管理管理Python版本和環境的工具。p–非常簡單的交互式python版本管理工具。pyenv–簡單的Pyth...
    MrHamster閱讀 3,850評論 1 61
  • GitHub 上有一個 Awesome - XXX 系列的資源整理,資源非常豐富,涉及面非常廣。awesome-p...
    若與閱讀 18,751評論 4 418
  • 語文作業: 聲母平舌音:z,c,s各寫一行,注意書寫要規范,不要寫的上大下小,半圓要寫圓,兒歌和拼讀各讀三遍!感謝配合
    瑞睿家閱讀 104評論 0 0
  • 本文總結「增長黑客」第四章激發活躍的內容,截取三個最主要點:A|B測試(灰度測試),曠日持久的補貼大戰(紅包補貼)...
    geekrun閱讀 3,607評論 0 1