python爬虫之爬取百度翻译

作者:世界的隐喻 时间:2022-04-03 19:30:45 

破解百度翻译

翻译是一件麻烦的事情,如果可以写一个爬虫程序直接爬取百度翻译的翻译结果就好了,可当我打开百度翻译的页面,输入要翻译的词时突然发现不管我要翻译什么,网址都没有任何变化,那么百度翻译要怎么爬取呢?

爬取百度翻译之前,我们先要明白百度翻译是怎么在不改变网址的情况下实现翻译的。百度做到这一点是用 AJAX 实现的,简单地说,AJAX的作用是在不重新加载网页的情况下进行局部的刷新。

了解了这一点,那么我们要怎么得到 AJAX 工作时请求的URL呢?老规矩,使用抓包工具。

爬虫步骤

在 “百度翻译” 页面右键,选择“Notework”选择 “ XHR ”

python爬虫之爬取百度翻译

如果画面没有任何数据,可以试着输入要翻译的词,比如说我输入“dog”时,就发生了如下的变化

python爬虫之爬取百度翻译

我们看到此时的 kw 是我要翻译的词,说明这是我们要找的东西。

(注意:我们发现其中有三个 sug ,我选的只是其中一个。如果我们全都带点开看,就会发现,他们的 kw 分别是:d 和 do。这是因为我打 dog 时一个单词一个单词打的,而 AJAX 是时时刷新。如果输入中文就不会出现这种情况。翻译中文时,我们找的也不是 sug 了,具体是什么,就看哪个包的 data 的值是我们要翻译的词。)

然后我们在回到上面,找到我们需要指定的 URL 、我们要选择的请求命令以及爬取到的数据的类型。

python爬虫之爬取百度翻译

欧克,做到这里我们的前期准备就完成了,下面就可以开始着手写代码了。


import requests

if __name__ == "__main__":
   # 指定 url
   url = "https://fanyi.baidu.com/sug"

# 要翻译的词
   keyword = input("需要翻译的词:")

data = {
       "kw": keyword
       }

# UA 伪装
   header = {
       "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.90 Safari/537.36"
       }

# 发送请求
   response = requests.post(url = url, data = data, headers = header).json()

print(response)

我们运行程序发现结果是这样的:

python爬虫之爬取百度翻译

因为请求到的数据比较短,所以我们比较容易地看出数据的结构是字典里有列表,列表里又有字典结构。如果比较长,我们可以使用在线 json 转换,转换后的数据是这样的

python爬虫之爬取百度翻译

我们只需要 dog 的释义,所以我们还可以对我们代码进行优化


print(response["data"][0]["v"])

注意

关于 data 的字典,并不是说只需要 “ kw ”: dog, data 的字典里要存储的是抓包工具里 from data 里所有的值,如果没有值,那么相对应的值就是空字符串。

如果学会了,你试着自己写一个破解有道翻译的爬虫程序吧!

来源:https://blog.csdn.net/ShiJieDeYinYu/article/details/115798323

标签:python,爬虫,百度,翻译
0
投稿

猜你喜欢

  • Python爬虫爬取ts碎片视频+验证码登录功能

    2023-03-23 01:39:23
  • Xml_javascript分页

    2008-09-04 14:43:00
  • 从网页设计开始

    2008-06-30 12:17:00
  • 用python实现学生信息管理系统

    2023-06-07 10:17:37
  • Date()与new Date()的区别

    2008-09-29 11:09:00
  • Python 图像处理 Pillow 库详情

    2022-12-05 04:46:12
  • numpy中np.c_和np.r_的用法解析

    2021-02-09 17:54:06
  • Pandas统计计数value_counts()的使用

    2023-11-24 10:28:46
  • IE6实现min-width

    2008-06-12 12:40:00
  • Python编程使用PyQt5库实现动态水波进度条示例

    2021-11-16 18:50:16
  • Python3中最常用的5种线程锁实例总结

    2022-06-19 08:21:02
  • Django使用channels + websocket打造在线聊天室

    2022-01-05 11:16:26
  • IE6浮出层穿透解决方案中的iframe高度自适应

    2009-10-30 18:08:00
  • Pandas 稀疏数据结构的实现

    2022-01-29 15:08:32
  • [JS效果]动画效果打开/关闭/移动层

    2008-04-10 11:42:00
  • CGArt®2008 贺岁刊电子杂志玉鼠闹春

    2008-02-15 08:59:00
  • 段正淳的css笔记(7)-表单在各浏览器的表现统一

    2008-01-14 02:47:00
  • 微信小程序实现图片上传功能

    2023-09-06 13:08:44
  • ASP设计常见问题及解答精要

    2009-04-21 11:16:00
  • python读取json文件并将数据插入到mongodb的方法

    2021-03-22 20:30:22
  • asp之家 网络编程 m.aspxhome.com