Python 使用openpyxl,requests读取excel进行接口测试

Excel内容如下:


image.png

具体实现
1、pycharm安装openpyxl

pip install openpyxl

2、requests库写接口函数
requests_util.py

import json as _json
import jsonpath
import requests
from common.log_util import logger


class HttpClient():
   __headers = {"content-type": "application/json;charset=UTF-8"}

   def __init__(self):
       self.__session = requests.session()

   def get(self, url, **kwargs):
       return self.__request(url, 'GET', **kwargs)

   def post(self, url, data=None, json=None, **kwargs):
       return self.__request(url, 'POST', data, json, **kwargs)

   def __request(self, url, method, data=None, json=None, **kwargs):
       headers = kwargs.get("headers")
       params = kwargs.get("params")

       if headers:
           self.__headers.update(headers)
       self.__request_log(url, method, data, json, params, self.__headers)
       resp = None
       if method == 'GET':
           resp = self.__session.get(url, **kwargs)
       elif method == 'POST':
           resp = requests.post(url, data, json, **kwargs)
       self.__response_log(resp)
       response_dicts = dict()
       response_dicts['text'] = resp.text
       return _json.loads(response_dicts['text'])

   def __request_log(self, url, method, data=None, json=None, params=None, headers=None):
       logger.info("接口请求地址:{}".format(url))
       logger.info("接口请求方式: {}".format(method))
       logger.info("接口请求头: {}".format(_json.dumps(headers, indent=4, ensure_ascii=False)))
       logger.info("接口请求 params 参数: {}".format(_json.dumps(params, indent=4, ensure_ascii=False)))
       logger.info("接口请求体 data 参数 : {}".format(_json.dumps(data, indent=4, ensure_ascii=False)))
       logger.info("接口请求体 json 参数: {}".format(_json.dumps(json, indent=4, ensure_ascii=False)))

   def __response_log(self, resp):
       try:
           logger.info("响应报文 : {}".format(resp.text, ensure_ascii=False))
       except Exception as e:
           logger.error('系统错误:{}'.format(e))

3、读取excel
excel_util.py

import openpyxl
from common import EXCEL_FILE, MEMBER_SERVICE_URL

class OperationExcel:
   def __init__(self,file_name=None,sheet_id=None):
       if file_name:
           self.file_name = file_name
           self.sheet_id = sheet_id
       else:
           self.file_name = EXCEL_FILE
           self.sheet_id = 0
           self.data = self.get_data()


   #获取sheets的内容
   def get_data(self):
       wb = openpyxl.load_workbook(self.file_name)
       tables = wb.worksheets[self.sheet_id]  # 获取表单
       return tables

   # 获取单元格的行数
   def get_lines(self):
       tables = self.data
       return tables.max_row
   #获取某一个单元格的内容
   def get_cell_value(self,row,col):
       return self.data.cell(row,col).value

#封装获取常量
class global_var:
   id = '1'
   case_id = '2'
   name = '3'
   url = '4'
   method = '5'
   header = '6'
   params = '7'
   json = '8'
   verify = '9'


def get_id():
   return global_var.Id
def get_case_id():
   return global_var.case_id
def get_request_name():
   return global_var.name
def get_url():
   return global_var.url
def get_method():
   return global_var.method
def get_header():
   return global_var.header
def get_params():
   return global_var.params
def get_json():
   return global_var.json
def get_verify():
   return global_var.verify

class Getheadervalue():
   def __init__(self,header):
       self.header = header
   def get_header_value(seif,header):
       return {
           "Content-Type":"application/json;charset=UTF-8"
       }


class GetData:
   def __init__(self):
       self.opera_excel = OperationExcel()
   # 获取excel行数,就是case的个数
   def get_case_lines(self):
       return self.opera_excel.get_lines()

   # 是否携带header
   def is_header(self,row):
       col = int(get_header())
       header = self.opera_excel.get_cell_value(row, col)
       return eval(header)

   # 获取请求方式
   def get_request_method(self,row):
       col = int(get_method())
       request_method = self.opera_excel.get_cell_value(row,col)
       return request_method

   # 获取url
   def get_request_url(self,row):
       col = int(get_url())
       url = MEMBER_SERVICE_URL+self.opera_excel.get_cell_value(row,col)
       return url

   # 获取case_id
   def get_case_id(self,row):
       col = int(get_case_id())
       case = self.opera_excel.get_cell_value(row,col)
       if case == None:
           return None
       return case

   # 获取请求数据
   def get_request_params(self,row):
       col = int(get_params())
       data = self.opera_excel.get_cell_value(row,col)
       if data == None:
           return None
       return eval(data)

   # 获取json报文数据
   def get_request_json(self,row):
       col = int(get_json())
       json_data = self.opera_excel.get_cell_value(row,col)
       if json_data == None:
           return None
       return eval(json_data)

   # 获取json path数据
   def get_verify_data(self,row):
       col = int(get_verify())
       verify_data = self.opera_excel.get_cell_value(row,col)
       if verify_data == None:
           return None
       return verify_data

4、执行接口测试
可放置在requests_util.py中

class RunHttp:
   def __init__(self):
       self.data = GetData()

   # 程序执行的
   def go_on_run(self,case=None):
       res = None
       rows_count = self.data.get_case_lines()
       for i in range(2, rows_count+1):
           case_id = self.data.get_case_id(i)
           if case_id == case:
               url = self.data.get_request_url(i)
               method = self.data.get_request_method(i)
               params = self.data.get_request_params(i)
               header = self.data.is_header(i)
               json = self.data.get_request_json(i)
               verify = self.data.get_verify_data(i)
               if method == 'get':
                   res = HttpClient().get(url=url, headers=header, params=params)
               elif method == 'post':
                   res = HttpClient().post(url=url, json=json, headers=header, params=params)
               verifystr = jsonpath.jsonpath(res, verify)
       return verifystr

httpRun = RunHttp()

if __name__ == '__main__':
   res=httpRun.go_on_run('customer_list_by_ouid')
   print(res)

也可参考python+openpyxl+excel实现接口测试自动化

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容