最近有研究接口测试,然后查了查资料,发现有两种方法,一种是使用urllib库,一种是使用requests库。而在这里,我使用的是requests库,为什么要用这个呢?
从官方文档看出,python的标准库urllib2提供了大部分需要的HTTP功能,但是呢?API太坑,使用标准库实现会写大堆代码。而requests使用起来的话,就比较简洁。(建议使用的开发工具是 pycharm,安装插件方便。)
下面别的不说,先上一个简单示例:
# -*- coding:utf-8 -*- __author__ = u'harry'
import requests #先导入包,这是必须的 url = 'http://XXXXXXXXXXXXXXX' #url:接口地址 data = {'XXXX':'XXX'} #data:接口传递的参数 headers = {'Connection':'close'} #header:传递header信息 #files:接口中需要上传文件则需要用到该参数 r = requests.post(url,data = data,headers = headers) #请求url,获得返回的数据信息 print(r.text.encode('utf-8')) #获得的返回数据使用text方法进行获取
使用requets就是这么简单。
简单的使用方法写了,各位客官可以对其进行很多的修改。比如说:封装这块代码,每次可以进行调用;可以添加循环,变为自动化,从excel中读取数据,然后进行循环取值。 等等等等。。。。
在最后再加上一个我封装后的urllib库 与 requests库的对比代码:
# -*- coding:utf-8 -*- __author__ = u'harry' import urllib.request import requests #先导入包,这是必须的 import urllib.parse url = 'XXXXXXX' # url:接口地址 data = {'XXX': 'XXX'} #data:接口传递的参数 headers = {'Connection': 'close'} # header:传递header信息 # files:接口中需要上传文件则需要用到该参数 def requests_test(url,data,headers): response = requests.post(url,data = data,headers = headers) #请求url,获得返回的数据信息 print(response.text,response.headers) #返回头部信息 def urllib_test(url,data): data1 = urllib.parse.urlencode(data).encode('utf-8') response = urllib.request.Request(url=url,data = data1) html = urllib.request.urlopen(response) print(html.read()) print(html.getcode(),html.msg) #获得html返回的状态 print(html.headers) #返回头部信息 #下面调用两个方法: urllib_test(url,data) requests_test(url,data,headers)
关于这两个库的get请求,我就不多讲了。
requests: requests.get("url")
urllib:不传入data就可以了。
如果要解决接口返回值的unicode编码,则
html.read().decode('unicode-escape')