---------------python2 和python3请求方式的区别
[^版权声明:本文为博主原创整理文章,未经博主允许不得转载 ]: https://blog.csdn.net/F_Liberalism 小白笔记,欢迎参考,欢迎提出修改意见
python 2 中提供了urllib和urllib2两个模块。
python 3 中有urllib和urllib3两个库, urllib几乎是Python2中urllib和urllib2两个模块的集合,所以我们最常用的urllib模块, 而urllib3则作为一个拓展模块使用
python 3 urllib.request 同意替换了python2中的urllib2 模块
1. 简单的实现post方法
### python2
import urllib
import urllib2
request = urllib2.Request('http://**.**.com/login/')
request.add_header(
'User-agent','Mozilla/5.0 (X11; U; Linux i686) Gecko/20071127 Firefox/2.0.0.11'
)
data = {'username':'melon','password':'passwd','authcode':'1234'}
encoded_data = urllib.urlencode(data)
request.add_data(encoded_data)
req = urllib2.urlopen(url, encoded_data)
print req
req.read()
req.close()
urllib2 中的 .add_data方法在python 3 中已经废弃,.add_data()是指传入参数数据,在python3 中可以在请求函数中传入
data= 参数的数据
###python3 urllib.request 带参数的post请求
import urllib.request
import urllib.parse
## 参数数据
data = urllib.parse.urlencode({'spam': 1, 'eggs': 2, 'bacon': 0})
data = data.encode('utf-8')
request = urllib.request.Request("http://requestb.in/xrbl82xr")
# adding charset parameter to the Content-Type header.
request.add_header("Content-Type","application/x-www-form-urlencoded;charset=utf-8")
f = urllib.request.urlopen(request, data)
print(f.read().decode('utf-8'))
2. GET的实现
浏览器输入网址直接访问是get 访问方式, 用 ?
拼接url,用 {}
传送参数数据, url=http://login.*.com/login.php?{name:“123”,“password”:“1234”}
### python 2.x 用urllib2 模块库 带参数的访问url
import urllib
import urllib2
login_data = {'name':'melon','password':'123456'}
login_url='http://login.*.com/login.php'
encoded_login_string = login_url+"?"+urllib.urlencode(login_data) login_req = urllib2.Request(encoded_login_string)
m = urllib2.urlopen(login_req).read()
print m
## python3 带参数的get访问请求
import urllib.request
import urllib.parse
params = urllib.parse.urlencode({'spam': 1, 'eggs': 2, 'bacon': 0})
f = urllib.request.urlopen("http://www.musi-cal.com/cgi-bin/query?%s" % params)
print(f.read().decode('utf-8'))
### python2.X 用request函数方式访问
url="http://localhost/testing/posting.php"
data= {
'subject': 'Alice-subject',
'message': 'alice-body',
'post': 'Submit',
}
cookies = {'phpbb2mysql_data': 'a%3A2%3A%7Bs%3A11%3A%22autologinid%22%3Bs%3A0%3A%22%22%3Bs%3A6%3A%22userid%22%3Bs%3A1%3A%223%22%3B%7D',
'phpbb2mysql_sid': '5b2e663a3d724cc873053e7ca0f59bd0',
}
#get方法
requests.get(url, data=data, cookies=cookies).text
#post方法, data 可以是字符串等
requests.post(url, data=data, cookies=cookies).text
3. urlencode方法的位置
在Python中,我们通常使用urllib中的urlencode方法将字典编码,用于提交数据给url等操作,但是在Python2和Python3中urllib模块中所提供的urlencode的包位置有些不同。
- python2 中urlencode方法所在位置为:
urllib.urlencode(values) # 其中values为所需要编码的数据,并且只能为字典
- Python 3 中 urlencode方法所在位置:
urllib.parse.urlencode(values)
from urllib import request
from urllib import parse
from urllib.request import urlopen
headers = {'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36'}
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'
#data参数如果要传必须传bytes(字节流)类型的,如果是一个字典,先用urllib.parse.urlencode()编码。
request = request.Request(url, data,headers = headers,method='GET')
response = urlopen(request)
print(response.read().decode())
4. urllib库导入的区别
urllib库是python提供的一个用于操作URL的模块,在python2中有urllib和urllib2,在python3中urllib2合并到urllib中,区别和联系如下:
python2.x | python3.x |
---|---|
import urllib2 | import urllib.request , import urllib.error |
import urllib | import urllib.request , import urllib.error,import urllib.parse |
import urlparse | import urllib.parse |
import urllib2.urlopen | import urllib.request.urlopen |
import urllib.urlencod | import urllib.parse.urlencode |
import urllib.quote | import urllib.request.quote |
import cookielib.CookieJar | import http.CookieJar |
参考链接:【侵删】
https://www.cnblogs.com/cocoajin/p/3679821.html
https://docs.python.org/3.4/library/urllib.request.html#module-urllib.request
https://blog.csdn.net/IMW_MG/article/details/78555375