Java-读取Excel
一、配置需要的jar包
1、需要在pom.xml中配置需要使用的包:org.apache.poi
<!--poi--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.10-FINAL</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.10-FINAL</version> </dependency> <!--poi-end-->
2、配置完成后,点击Maven-install,Maven会自动下载包
二、准备一个Excel,数据如下
三、第一种实现方式:使用List<List<String>>来存放读取的数据
1、创建一个java类:ExcelUtil
import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.ss.usermodel.*; import java.io.*; import java.util.*; public class ExcelUtil { Member member = new Member(); public static List<List<String>> getExcel(String filePath, String sheetName) { List<List<String>> dataList = new ArrayList<>();//用来存放从Excel中读取的数据 Workbook wb = null; try { InputStream is = new FileInputStream(filePath);//打开Excel文件 wb = WorkbookFactory.create(is);//创建一个Workbook对象 is.close();//关闭输入流 if (wb != null) { Sheet sheet = wb.getSheet(sheetName);//根据sheet页的名字来获取sheet对象 //Sheet sheet = wb.getSheetAt(0);//获取下标为0的sheet页 int maxRownum = sheet.getLastRowNum();//获取的是最后一行的编号(编号从0开始)。 //int maxRownum = sheet.getPhysicalNumberOfRows();//获取的是物理行数,也就是不包括那些空行(隔行)的情况。 Row firstRow = sheet.getRow(0);//获取第一行的row对象 int maxColnum = firstRow.getPhysicalNumberOfCells();//获取第一行的最大列的下标 System.out.println(maxColnum); for (int i=0;i<=maxRownum;i++){//循环行 List<String> list = new ArrayList<>();//创建一个list用来存放每一行的值 String estr ="";//用来存放单元格的值 for (int j=0;j<maxColnum;j++){//循环列 if (sheet.getRow(i).getCell(j) != null) {//判断单元格是否为空 estr = sheet.getRow(i).getCell(j).toString();//取出这个单元格的值 }else { estr=""; } //System.out.println(firstColumns+"---"+estr); list.add(estr);//把单元格的值放到list里 } dataList.add(list);//list添加到list里 } //System.out.println(dataList); } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (InvalidFormatException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return dataList;//返回list } }
2、写一个ExcelTest类来测试
import java.util.List; public class ExcelTest { public static void main(String[] args) { String filePath = "/Users/renli/PycharmProjects/untitled/testFile/SendCredit.xlsx";//Excel存放的路径(我的电脑是macbook所以没有盘符) String sheetName = "Sheet1";//需要获取的sheetName List<List<String>> rows = ExcelUtil.getExcel(filePath, sheetName);//调用getExcel方法,获取到一个List<List<String>> //System.out.println(rows); //System.out.println(rows.size()); for (List<String> list:rows) { System.out.println(list.get(0) + "---->" + list); int i = 0; for (String s : list) { System.out.println("测试编码为 " + list.get(0) + " 的第 " + (i + 1) + " 个值:" + s); i++; } } } }
执行结果
三、第二种实现方式:使用Map<String, List<String>>来存放读取的数据
1、创建一个java类:ExcelUtil
import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.WorkbookFactory; import java.io.*; import java.util.*; public class ExcelUtil { public static Map<String, List<String>> getExcel(String filePath, String sheetName) { Map<String, List<String>> dataList = new HashMap<>();//用来存放从Excel中读取的数据 Workbook wb = null; try { InputStream is = new FileInputStream(filePath);//打开Excel文件 wb = WorkbookFactory.create(is);//创建一个Workbook对象 is.close();//关闭输入流 if (wb != null) { Sheet sheet = wb.getSheet(sheetName);//根据sheet页的名字来获取sheet对象 //Sheet sheet = wb.getSheetAt(0);//获取下标为0的sheet页 //int rows = sheet.getLastRowNum();//获取的是最后一行的编号(编号从0开始)。 int maxRownum = sheet.getPhysicalNumberOfRows();//获取的是物理行数,也就是不包括那些空行(隔行)的情况。 Row firstRow = sheet.getRow(0);//获取第一行的row对象 int maxColnum = firstRow.getPhysicalNumberOfCells();//获取第一行的最大列的下标 //System.out.println(maxColnum); for (int i=0;i<maxRownum;i++){//循环行 List<String> list = new ArrayList<>();//创建一个list用来存放每一行的值 String firstColumns = sheet.getRow(i).getCell(0).toString();//获取每一行的第一列的值,用来做map的Key String estr ="";//用来存放单元格的值 for (int j=0;j<maxColnum;j++){//循环列 if (sheet.getRow(i).getCell(j) != null) {//判断单元格是否为空 estr = sheet.getRow(i).getCell(j).toString();//取出这个单元格的值 }else { estr=""; } //System.out.println(firstColumns+"---"+estr); list.add(estr);//把单元格的值放到list里 } dataList.put(firstColumns,list);//把list存放到map里 } //System.out.println(dataList); } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (InvalidFormatException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return dataList;//返回map } }
2、写一个ExcelTest类来测试
import java.util.List; import java.util.Map; public class ExcelTest { public static void main(String[] args) { String filePath = "/Users/renli/PycharmProjects/untitled/testFile/SendCredit.xlsx";//Excel存放的路径(我的电脑是macbook所以没有盘符) String sheetName = "Sheet1";//需要获取的sheetName Map<String, List<String>> rows = ExcelUtil.getExcel(filePath, sheetName);//调用getExcel方法,获取到一个Map<String, List<String>> //System.out.println(rows); //System.out.println(rows.size()); //第一种方式:推荐,尤其是容量大时 System.out.println("\n通过Map.entrySet遍历key和value"); for (Map.Entry<String, List<String>> entry : rows.entrySet()) { String key = entry.getKey(); List<String> list = entry.getValue(); System.out.println(key + "---->" + list); int i = 0; for (String s : list) { System.out.println("测试编码为 " + key + " 的第 " + (i + 1) + " 个值:" + s); i++; } } //第二种方式:普通使用,二次取值(性能差) System.out.println("\n通过Map.keySet遍历key和value:"); for (String key : rows.keySet()) {//取出Map中所有的Key的值,遍历 System.out.println(key + "---->" + rows.get(key)); List<String> list = rows.get(key);//取出Map中Key为key的value的值,赋值给一个list for (int i = 0; i < list.size(); i++) {//循环遍历list //list.get(i)根据下标获取值 System.out.println("测试编码为 " + key + " 的第 " + (i + 1) + " 个值:" + list.get(i).toString()); } } } }
执行结果