zoukankan      html  css  js  c++  java
  • 【Java】之获取CSV文件数据以及获取Excel文件数据

    一、获取CSV文件数据

    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    import org.testng.SkipException;
    import org.testng.annotations.DataProvider;
    import org.testng.annotations.Test;
    
    import java.io.*;
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    
    
    public class DataProviderTest {
    
    
        public Iterator<Object[]> readDataFromCSV(String path){
            //  读取CSV文件方法
            List<Object[]> list = new ArrayList<Object[]>();
            try {
                FileReader is = new FileReader(new File(path));
                BufferedReader br = new BufferedReader(is);
                while(br.ready()){
                    list.add(br.readLine().split(","));
                }
                return list.iterator();
            } catch (Exception e) {
                throw new SkipException(e.getMessage());
            }
        }
    
    
        @DataProvider
        public Iterator<Object[]> getData1() throws UnsupportedEncodingException {
            //  获取CSV方法
            String path = this.getClass().getResource("test.xlsx").getPath();
            String path1 = java.net.URLDecoder.decode(path, "utf-8");
            System.out.println(path1);
            return readDataFromCSV(path1);
    
        }
    
    
        @Test(dataProvider = "getData1")
        public void test1(String text1,String text2) {
            //  打印CSV数据
            System.out.println(text1);
            System.out.println(text2);
    
        }
    }

    二、获取Excel文件数据

    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    import org.testng.SkipException;
    import org.testng.annotations.DataProvider;
    import org.testng.annotations.Test;
    
    import java.io.*;
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    
    
    
    
    /**
     * @author zc
     * @date 2021-01-21 17:18
     */
    
    public class DataProviderTest {
    
    
        public Object[][] getDataFromExcel(String excelPath){
            //  读取excel文件方法
            Workbook book;
            try {
                FileInputStream f = new FileInputStream(excelPath);
                book = new XSSFWorkbook(f);
                Sheet sheet = book.getSheetAt(0);
                int rowInExcel = sheet.getPhysicalNumberOfRows();
                int columnInExcel = sheet.getRow(0).getPhysicalNumberOfCells();
                String[][] obj = new String[rowInExcel-2][columnInExcel];
                for (int row = 2; row < rowInExcel; row++) {
                    for (int col = 0; col < columnInExcel; col++) {
                        sheet.getRow(row).getCell(col).setCellType(Cell.CELL_TYPE_STRING);
                        obj[row-2][col] = sheet.getRow(row).getCell(col).getStringCellValue();
                        System.out.println(obj[row-2][col]);
                    }
                }
                return obj;
            } catch (Exception e) {
                // TODO Auto-generated catch block
                throw new SkipException(e.getMessage());
            }
        }
    
    
        @DataProvider
        public Object[][] getData2() throws UnsupportedEncodingException {
            //  获取excle方法
            String path = this.getClass().getResource("test.xlsx").getPath();
            String path1 = java.net.URLDecoder.decode(path, "utf-8");
            System.out.println(path1);
            return getDataFromExcel(path1);
        }
    
    
    
        @Test(dataProvider = "getData2")
        public void test1(String text1,String text2) {
            //  打印CSV数据
            System.out.println(text1);
            System.out.println(text2);
    
        }
    }

    不积跬步,无以致千里;不集小流,无以成江海。 ; 如转载本文,请还多关注一下我的博客:Owen_ET,https://www.cnblogs.com/Owen-ET/
  • 相关阅读:
    error: device not found
    RK3288 查看时钟树
    GPS数据包格式解析
    Android 操作文件系统失败: Read-only file system
    Ubuntu 14.04 配置安卓5.1编译环境
    升级 php composer 版本
    清理 laravel blade 模板缓存
    Laravel collection 报错 join(): Invalid arguments passed
    Laravel firstOrNew 与 firstOrCreate 的区别
    执行 crontab 的计划任务
  • 原文地址:https://www.cnblogs.com/Owen-ET/p/14373399.html
Copyright © 2011-2022 走看看