java+selenium 做Excel数据驱动测试举例(二)

21 篇文章 1 订阅
11 篇文章 0 订阅

这部分直接用二维数组,涉及到传参优化。
1、数据提供的类

package dao;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.testng.annotations.DataProvider;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;

import java.util.List;

/**
 * @author wangyan
 * @date 2019-02-20  下午 04:55
 */
//这里是数据提供者,调用mapDataProvider方法
public class DataProviderSet_xlsx {

    @DataProvider(name="mapDataProvider")
    public static Object[][] words() throws IOException
    {
        return mapDataProvider("D:\\work_space\\resources", "testdata.xlsx", "test");

    }

    public static Object[][] mapDataProvider(String filePath,String fileName,String sheetName) throws IOException {
//        fileName="testdata";
//        sheetName="test";
//        File file=new File(filePath+"\\"+fileName);
//        FileInputStream input=new FileInputStream(file);
        Workbook workbook=null;
        String fileExtensionName=fileName.substring(fileName.indexOf("."));
        
        InputStream in=null;
        DataFormatter dataFormatter=new DataFormatter();

            in = DataProviderSet_xlsx.class.getClassLoader().getResourceAsStream(fileName);
            if (fileExtensionName.equalsIgnoreCase(".xlsx")) {
                workbook = new XSSFWorkbook(in);
            } else if (fileExtensionName.equalsIgnoreCase(".xls")) {
                workbook = new HSSFWorkbook(in);
            }

            //获取sheet
            Sheet sheet = workbook.getSheet(sheetName);
            //获取总行数
            int row = sheet.getLastRowNum() - sheet.getFirstRowNum();
            List<Object[]> records = new ArrayList<Object[]>();

            for (int i = 1; i < row + 1; i++) {
                Row rowValue = sheet.getRow(i);
                String[] files = new String[rowValue.getLastCellNum()];
                List<Cell> cells=null;

                for (int j = 0; j < rowValue.getLastCellNum(); j++) {

                    files[j]=dataFormatter.formatCellValue(rowValue.getCell(j));



                }
                records.add(files);

            }
            System.out.println("records"+records.get(0));
            Object[][] results = new Object[records.size()][];
            for (int i = 0; i < records.size(); i++) {

                results[i] = records.get(i);

            }
            return results;


    }
}

2、测试类,获取数据`


package configSelenium.Assert;

import dao.DataProviderSet_xlsx;

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

import java.util.*;

/**
 * @author wangyan
 * @date 2019-02-18  下午 04:55
 *
 */
public class sql {
    @Test(dataProvider = "mapDataProvider",dataProviderClass = DataProviderSet_xlsx.class)
    public void testMapDataProviderFromExcel(String var1,String var2,String var3){
         System.out.println("var1:"+var1+"\nvar2:"+var2+"\nvar3:"+var3);
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值