Python2和Python3中urllib库中urlencode的使用注意事项

时间:2022-10-15 06:38:22

前言

Python中,我们通常使用urllib中的urlencode方法将字典编码,用于提交数据给url等操作,但是在Python2Python3urllib模块中所提供的urlencode的包位置有些不同。


对于Python2

Python2中提供了urlliburllib2两个模块。

  • 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中也有urlliburllib3两个库,其中urllib几乎是Python2urlliburllib2两个模块的集合,所以我们最常用的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())