urllib库的使用下

urllib的post请求方式的实现
  • 在上篇文章中介绍了urllib的get请求方式以及字符串格式的解决,这篇文章介绍urllib库的post请求实现方式:
  • 以有道翻译为例:
    思路:
  1. 获取对象的url地址:
  2. 向携带数据向服务器发起请求
  3. 获取服务器响应
  4. 解析获得的数据

首先我们在浏览器找到对应的url地址以及from表单:如下
url地址
form表达

import urllib.request
import urllib.parse
import json
user_data = input("请输入你要翻译的句子: ")
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.85 Safari/537.36 '}
data = {
	'i': user_data,
    'from': 'AUTO',
    'to': 'AUTO',
    'smartresult': 'dict',
    'client': 'fanyideskweb',
    'salt': '16194076798873',
    'sign': '74f985e32009290f13a543f7255091ef',
    'lts': '1619407679887',
    'bv': '62c1eba97402d4ff4eb261254e974c27',
    'doctype': 'json',
    'version': '2.1',
    'keyfrom': 'fanyi.web',
    'action': 'FY_BY_REALTlME',
}
#  将i后面对应的值改为对应的变量
url = 'https://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'

req = urllib.parse.urlencode(data)
#将data数据编码。

req = bytes(req,'utf-8')
#将数据转换为bytes类型并指定格式,如果不转换则会抛出
# TypeError: POST data should be bytes, an iterable of bytes, or a file object. It cannot be of type str

res = urllib.request.Request(headers=headers,url=url,data=req)
#携带数据向服务器发起请求

respons = urllib.request.urlopen(res)
#获取服务器响应

html = respons.read().decode('utf-8')
#读取数据

d_dict = json.loads(html)
#讲json格式的字符串转换为python格式

data = d_dict['translateResult'][0][0]['tgt']
#获取翻译之后的数据

print(data)
#注意的地方:
#1.数据类型,需要将数据转换为字节类型并指定格式
#2.需要去除url地址中'_o'。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值