前言
在Python
中,我們通常使用urllib
中的urlencode
方法將字典編碼,用於提交數據給url
等操作,但是在Python2
和Python3
中urllib
模塊中所提供的urlencode
的包位置有些不同。
對於Python2
Python2
中提供了urllib
和urllib2
兩個模塊。
urlencode
方法所在位置為:
urllib.urlencode(values) # 其中values為所需要編碼的數據,並且只能為字典
- 1
- 例如模擬登陸CSDN網站,示例程序如下
import urllib2 values = {"username":"962457839@qq.com","password":"XXXX"} data = urllib.urlencode(values) url = "https://passport.csdn.net/account/login?from=http://my.csdn.net/my/mycsdn" request = urllib2.Request(url,data) response = urllib2.urlopen(request) print response.read()
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
對於Python3
Python3
中也有urllib
和urllib3
兩個庫,其中urllib
幾乎是Python2
中urllib
和urllib2
兩個模塊的集合,所以我們最常用的urllib
模塊,而urllib3
則作為一個拓展模塊使用。
urlencode
方法所在位置
urllib.parse.urlencode(values)
- 1
- 例如模擬登陸CSDN網站,示例程序如下:
from urllib import request from urllib import parse from urllib.request import urlopen values = {'username': '962457839@qq.com', 'password': 'XXXX'} data = parse.urlencode(values).encode('utf-8') # 提交類型不能為str,需要為byte類型 url = 'https://passport.csdn.net/account/login?from=http://my.csdn.net/my/mycsdn' request = request.Request(url, data) response = urlopen(request) print(response.read().decode())