爬取有道页面,实现中文翻译成英文:

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

'''
Created on 2018-7-12
@author: sss
功能:爬取有道翻译 '''
import urllib
import urllib.request
import urllib.parse
import urllib.response
from pip._vendor.urllib3.filepost import encode_multipart_formdata
from pip._vendor.distlib.compat import raw_input
import json
import random # url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null"
url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule" #http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule要把_o去掉 #user-agent列表,每次请求随机选一个:
ua_list = [
"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36",
"Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko",
"Mozilla/5.0 (X11; CrOS i686 2268.111.0)like Gecko",
"Mozilla/5.0 (Macintosh; U; PPC Mac OS X ",
"Mozilla/5.0 (Macintosh; Intel Mac OS "
] user_agnet = random.choice(ua_list) headers = {
"Connection" : "keep-alive",
"Accept" : "application/json, text/javascript, */*; q=0.01",
"X-Requested-With" : "XMLHttpRequest",
"User-Agent" : user_agnet,
"Content-Type" : "application/x-www-form-urlencoded; charset=UTF-8",
"Referer" : "http://fanyi.youdao.com/"
} key = raw_input("请输入需要翻译的文字:\n") formdata = {
"i" :key,
"from " :"AUTO",
"to" :"AUTO",
"smartresult" :"dict",
"client" :"fanyideskweb",
"salt" :"1531403738742", #这个应该是个时间戳
"sign" :"ffa2b29fe52953208226d97a174bcea7", #应该是根据时间戳+你要翻译的内容加密后生成的验证字段
"doctype" :"json",
"version" :"2.1",
"keyfrom" :"fanyi.web",
"action" :"FY_BY_REALTIME",
"typoResult" :"false"
} data = urllib.parse.urlencode(formdata ).encode(encoding='UTF8') #这里后面要加encoding='utf-8' request = urllib.request.Request(url, data = data, headers = headers) html = urllib.request.urlopen(request).read()
print(html) print('完成!') target = json.loads(html)
print("翻译结果:%s"%(target['translateResult'][0][0]['tgt'])) #读出结果 print(headers)

  

最新文章

  1. 【原】使用Bmob作为iOS后台开发心得——查询关联关系(BmobRelation)
  2. Ubuntu 安装 CLI 并运行 ASP.NET Core 1.0
  3. expect基本使用方法
  4. [8.2] Robot in a Grid
  5. git 使用技巧
  6. uva 10668
  7. C#事件解析
  8. (一)javascript中的数组index属性——获取数组的索引值
  9. boost::bind实践
  10. PullToRefreshListView 内嵌checkbox 数据丢失问题
  11. 集群安装配置Hadoop具体图解
  12. asp.net mvc3 数据验证(二)——错误信息的自定义及其本地化
  13. KVM下windows虚拟机使用virtio驱动
  14. jquery实现链接的title快速出现
  15. android O 打开设置->声音->“点按时震动问题”
  16. iOS进阶之TCP代理鉴权过程
  17. 2019/4/18 wen 线程
  18. Java基础4-面向对象概述;super();this()
  19. java笔记 -- java变量与常量的声明
  20. mongodb副本集数据同步的踩坑

热门文章

  1. Python开发简单记事本
  2. kali视频(1-5)
  3. C# 操作嵌入的资源
  4. C#结构体数组间的转化
  5. is is not == !=之间的区别
  6. web 面试题、简单题、复习题
  7. zabbix 执行自定义key脚本超时
  8. fuser命令
  9. 关于sea.js的笔记
  10. 解决时间控件input不能选择的问题