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())