Python2和Python3中urllib库中urlencode的使用注意事项
前言
在Python
中,我们通常使用urllib
中的urlencode
方法将字典编码,用于提交数据给url
等操作,但是在Python2
和Python3
中urllib
模块中所提供的urlencode
的包位置有些不同。
对于Python2
Python2
中提供了urllib
和urllib2
两个模块。
urlencode
方法所在位置为:
urllib.urlencode(values) # 其中values为所需要编码的数据,并且只能为字典
- 例如模拟登陆豆瓣,示例程序如下
import urllib import urllib2 values = {"username":"*****","password":"******"} data = urllib.urlencode(values) url = "https://accounts.douban.com/login" request = urllib2.Request(url,data) response = urllib2.urlopen(request) print response.read()
对于Python3
Python3
中也有urllib
和urllib3
两个库,其中urllib
几乎是Python2
中urllib
和urllib2
两个模块的集合,所以我们最常用的urllib
模块,而urllib3
则作为一个拓展模块使用。
urlencode
方法所在位置
urllib.parse.urlencode(values)
- 例如模拟登陆豆瓣,示例程序如下:
from urllib import request from urllib import parse from urllib.request import urlopen values = {'username': '*****', 'password': '*****'} data = parse.urlencode(values).encode('utf-8') # 提交类型不能为str,需要为byte类型 url = 'https://accounts.douban.com/login' request = request.Request(url, data) response = urlopen(request) print(response.read().decode())