# -*- coding: utf-8 -*-
"""
Created on Sat Jul 14 15:19:43 2018
@author: Python
"""
from urllib import request, parse
import re
def getTInfo(key):
# 通过抓包的方式获取的url,并不是浏览器上显示的url
url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
# 这里的headers及formdata是从浏览器中获取到的
headers = {
"Accept" : "application/json, text/javascript, */*; q=0.01",
"X-Requested-With" : "XMLHttpRequest",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0",
"Content-Type" : "application/x-www-form-urlencoded; charset=UTF-8",
}
formdata = {
"i":key,#key是参数传递进来的
"from":"auto",
"to":"auto",
"smartresult":"dict",
"client":"fanyideskweb",
"salt":"1511219405946",
"sign":"f8965f67a1d3eee8a69ddf8ccc5f582b",
"doctype":"json",
"version":"2.1",
"keyfrom":"fanyi.web",
"action":"FY_BY_REALTIME",
"typoResult":"false"
}
# 做一次urlencode
data=bytes(parse.urlencode(formdata),encoding='utf-8')
#利用Request将headers,dict,data整合成一个对象传入urlopen
req = request.Request(url,data,headers,method='POST')
response = request.urlopen(req)
info = response.read().decode('utf-8') # 这里需要做一次utf-8转码
# 因为这里需要对信息做文本的处理
# 使用正则表达式提取翻译出的信息
strRule = re.compile('"tgt":(.*?)}')
info2 = strRule.findall(info)
for i in info2:
i = i.replace('"',"")
return info2[0]
def printInfo(s, collapse=0):
processFun = collapse and (lambda s:" ".join(s.split())) or (lambda s:s)
return processFun(s)
def info(object, spacing=15, collapse=1):
"""
遍历一遍Object对象,把里面可以被调用的方法及方法
的doc string打印出来
"""
# 第一步:提取出当前Object可以被调用的方法列表
methodList = [method for method in dir(object) if callable(getattr(object, method))]
#print(methodList)
# 需要把doc string的方法按照一个的格式提取出来
processFun = collapse and (lambda s:" ".join(s.split()))or (lambda s:s)
# 打印出方法的名称及其文档的说明
print( '\n'.join(["%s %s"%( method.ljust(spacing) , processFun(str(getattr(object, method).__doc__)) ) for method in methodList]) )
return '\n'.join(["%s %s"%( method.ljust(spacing) , processFun(str(getattr(object, method).__doc__)) ) for method in methodList])
if __name__ == "__main__":
# from multiprocessing import Process
tt = info(m)#m 是要翻译的方法
translate = tt.split('\n')
for word in translate:
print(getTInfo(word))