urllib的post请求方式的实现
- 在上篇文章中介绍了urllib的get请求方式以及字符串格式的解决,这篇文章介绍urllib库的post请求实现方式:
- 以有道翻译为例:
思路:
- 获取对象的url地址:
- 向携带数据向服务器发起请求
- 获取服务器响应
- 解析获得的数据
首先我们在浏览器找到对应的url地址以及from表单:如下
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'。