利用python爬取有道词典的方法


Posted in Python onDecember 08, 2020

前言

大家好

​ 最近python爬虫有点火啊,啥python爬取马保国视频……我也来凑个热闹,今天我们来试着做个翻译软件……不是不是,说错了,今天我们来试着提交翻译内容并爬取翻译结果

主要内容

 材料

1.Python 3.8.4

2.电脑一台(应该不至于有”穷苦人家“连一台电脑都没有吧)

3.Google浏览器(其他的也行,但我是用的Google)

写程序前准备

打开Google浏览器,找的有道词典的翻译网页(http://fanyi.youdao.com/)

打开后摁F12打开开发者模式,找Network选项卡,点击Network选项卡,然后刷新一下网页

然后翻译一段文字,随便啥都行(我用的程序员的传统:hello world),然后点击翻译

在选项卡中找到以translate开头的post文件

利用python爬取有道词典的方法

箭头的地方才是真正的提交地址

记住他,写代码时要用

利用python爬取有道词典的方法

这个是提交电脑的基本信息,记住他,等会儿要用,等会儿伪装成电脑时可以用,因为电脑会有基本信息,而如果是python的话会显示成python3.8.4(因为我的版本是3.8.4),从而容易被服务器禁入

利用python爬取有道词典的方法

等会儿还要用

好,准备工作做完了,接下来开始干正事了

开始编写爬虫代码

下面是我写的代码,具体我就不细说了

#导入urllib库
import urllib.request
import urllib.parse
import json

while True: #无限循环
 content = input("请输入您要翻译的内容(输入 !!! 退出程序): ")
 #设置退出条件
 if content == '!!!':
  break

 url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule' #选择要爬取的网页,上面找过了
 #加上一个帽子,减少被发现的概率(下面head列表的内容就是上面找的)
 head = {}
 head['User - Agent'] = '请替换'

 #伪装计算机提交翻译申请(下面的内容也在在上面有过,最好根据自己的进行修改)
 data = {}
 data['type'] = 'AUTO'
 data['i'] = content
 data['doctype'] = 'json'
 data['version'] = '2.1'
 data['keyfrom:'] = 'fanyi.web'
 data['ue'] = 'UTF-8'
 data['typoResult'] = 'true'
 data = urllib.parse.urlencode(data).encode('utf-8')

 response = urllib.request.urlopen(url, data)
 #解码
 html = response.read().decode('utf-8')

 paper = json.loads(html)

 #打印翻译结果
 print("翻译结果: %s" % (paper['translateResult'][0][0]['tgt']))

运行结果

利用python爬取有道词典的方法

到此这篇关于python爬取有道词典的文章就介绍到这了,更多相关python有道词典内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python使用新浪微博api上传图片到微博示例
Jan 10 Python
Python中字典的浅拷贝与深拷贝用法实例分析
Jan 02 Python
Python使用matplotlib绘制余弦的散点图示例
Mar 14 Python
python操作redis方法总结
Jun 06 Python
解决pandas中读取中文名称的csv文件报错的问题
Jul 04 Python
Python集中化管理平台Ansible介绍与YAML简介
Jun 12 Python
Python @property使用方法解析
Sep 17 Python
基于Python批量生成指定尺寸缩略图代码实例
Nov 20 Python
python 实现保存最新的三份文件,其余的都删掉
Dec 22 Python
基于Pyinstaller打包Python程序并压缩文件大小
May 28 Python
使用tensorflow 实现反向传播求导
May 26 Python
详解Python中的进程和线程
Jun 23 Python
Python控制鼠标键盘代码实例
Dec 08 #Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
Dec 08 #Python
解决pycharm导入numpy包的和使用时报错:RuntimeError: The current Numpy installation (‘D:\\python3.6\\lib\\site-packa的问题
Dec 08 #Python
Python爬虫之App爬虫视频下载的实现
Dec 08 #Python
Python爬虫进阶之爬取某视频并下载的实现
Dec 08 #Python
selenium框架中driver.close()和driver.quit()关闭浏览器
Dec 08 #Python
Python hashlib和hmac模块使用方法解析
Dec 08 #Python
You might like
php除数取整示例
2014/04/24 PHP
php中debug_backtrace、debug_print_backtrace和匿名函数用法实例
2014/12/01 PHP
PHP常用字符串操作函数实例总结(trim、nl2br、addcslashes、uudecode、md5等)
2016/01/09 PHP
Laravel5框架添加自定义辅助函数的方法
2018/08/01 PHP
JavaScript 异步调用框架 (Part 3 - 代码实现)
2009/08/04 Javascript
jquery动画4.升级版遮罩效果的图片走廊--带自动运行效果
2012/08/24 Javascript
JS中把字符转成ASCII值的函数示例代码
2013/11/21 Javascript
JS对象转换为Jquery对象实现代码
2013/12/29 Javascript
js+csss实现的一个带复选框的下拉框
2014/09/29 Javascript
JQuery CheckBox(复选框)操作方法汇总
2015/04/15 Javascript
JavaScript对表格或元素按文本,数字或日期排序的方法
2015/05/26 Javascript
JavaScript的Polymer框架中dom-repeat与VM的相关操作
2015/07/29 Javascript
JS模拟按钮点击功能的方法
2015/12/22 Javascript
JS清除文本框内容离开在恢复及鼠标离开文本框时触发js的方法
2016/01/12 Javascript
JavaScript头像上传插件源码分享
2016/03/29 Javascript
41个Web开发者必须收藏的JavaScript实用技巧
2016/07/22 Javascript
Angularjs中$http以post请求通过消息体传递参数的实现方法
2016/08/05 Javascript
实例浅析js的this
2016/12/11 Javascript
微信小程序 传值取值的几种方法总结
2017/01/16 Javascript
js for循环倒序输出数组元素的实例
2017/03/01 Javascript
基于rem的移动端响应式适配方案(详解)
2017/07/07 Javascript
Vue slot用法(小结)
2018/10/22 Javascript
JavaScript事件循环及宏任务微任务原理解析
2020/09/02 Javascript
[02:58]献给西雅图的情书_高清
2014/05/29 DOTA
Python中不同进制互相转换(二进制、八进制、十进制和十六进制)
2015/04/05 Python
简单谈谈python中的多进程
2016/11/06 Python
python2和python3应该学哪个(python3.6与python3.7的选择)
2019/10/01 Python
python Socket网络编程实现C/S模式和P2P
2020/06/22 Python
PyQt中使用QtSql连接MySql数据库的方法
2020/07/28 Python
经济职业学院毕业生自荐书
2014/03/17 职场文书
《中国梦我的梦》中学生演讲稿
2014/08/20 职场文书
机关作风建设工作总结
2014/10/23 职场文书
2015年家长学校工作总结
2015/04/22 职场文书
2015年领导干部廉洁自律工作总结
2015/05/26 职场文书
导游词之任弼时故居
2020/01/07 职场文书
python多次执行绘制条形图
2022/04/20 Python