pytest之公共类封装读取excel(pandas)

import pandas as pd
import os
import yaml

abs_path = os.path.abspath(__file__)
# 三种方式
project_path = os.path.dirname(abs_path).rstrip('\\common')
# project_path = os.path.dirname(abs_path).replace('\\common','')
# project_path = os.path.dirname(abs_path)[0:len(os.path.dirname(abs_path))-6]

def read_excel(filePath, sheet_name):
    df = pd.read_excel((project_path+filePath), sheet_name=sheet_name)
    # 获取EXCEL的行数0,列数1
    lines_count = df.shape[0]
    print('lines_count:',lines_count)
    # 获取EXCEL的列数
    cols_count = df.shape[1]

    result_data = []
    lines_data = []
    for i in range(lines_count):
        lines_data = []
        for j in range(cols_count):
            cell_data = df.iloc[i, j]
            # 把不是str类型的数据都装为int
            if not isinstance(cell_data, str):
                cell_data = int(cell_data)
            print('cell_data',cell_data)
            lines_data.append(cell_data)
        result_data.append(lines_data)
    print('result_data.append(lines_data):',result_data)
    return result_data
from common.excel_util import read_excel

@pytest.mark.parametrize('casename,title, author, content, createUser,expect_code,expect_message', read_excel(r'\data\testCases.xlsx', 'Sheet1'))
def test_buy_now_params(casename, title, author, content, createUser, expect_code, expect_message):
    print('casename,title, author, content, createUser,expect_code,expect_message:',casename, title, author, content, createUser, expect_code, expect_message)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值