Python爬虫|有道翻译(简易版)

本篇文章利用url接口删除"_o",巧妙的避开了反爬措施,代码简单易懂,后续将出一篇进阶版,不删除"_o"进行反爬

import requests
import json

#1.基于控制台获取输入-等待翻译的词语
content=input('请输入:')
#2.设定待请求的url
url='https://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
#3.建立post表单
post_form={
    'i': content,
    'from': 'AUTO',
    'to': 'AUTO',
    'smartresult': 'dict',
    'client': 'fanyideskweb',
    'salt': '16347335106665',
    'sign': 'db02fd478420666d08c63a3b7eae1520',
    'lts': '1634733510666',
    'bv': 'd5224460610b3619bf4d2f035423e0ab',
    'doctype': 'json',
    'version': '2.1',
    'keyfrom': 'fanyi.web',
    'action': 'FY_BY_REALTlME'
    
}
#提交post请求
response=requests.post(url,data=post_form)
#接收响应结果,并解析提取
trans_json=response.text
trans_dict=json.loads(trans_json)
result=trans_dict['translateResult'][0][0]['tgt']
print(result)

代码详解:

1.代码中的url从哪里来???

从该页发现了相关的值,于是抓取该页面的URL

在这里插入图片描述
获取到的页面为
url=‘https://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule’
但是当试图进行抓取该接口时,并没有返回值(大概是有道的一种反爬手段)
解决办法(参照网上大佬的):删除translate后的_o
url=‘https://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule’

代码中的post_form从哪里来??
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

向阳-Y.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值