一、解析Excel文件
在解析Excel之前,首要任务是手动下载并在项目中添加POI第三方库;其次要了解到Excel的后缀名:旧版本的Excel是以.xsl结尾,新版本的Excel是以.xlsx结尾;旧版本用HXSSFWorkbook类进行解析,而新版本使用XSSFWorkbook类进行解析。步骤如下:
首先,在创建一个Workbook对象同时要传入一个输入流对象,其目的是得到解析对象;其次,获取了Workbook对象相当获取到Excel文件、通过Workbook对象的getSheet()方法创建Sheet对象相当于获取Excel文件中的工作簿、接着通过Sheet对象的getRow()方法创建Row对象相当于获取工作簿中的行、最后通过Row对象创建Cell对象相当于获取行中的单元格。
代码如下:
// 1.得到一个输入流对象
FileInputStream in = new FileInputStream("E:\\JavaTest\\1627356552686.xlsx");
try (
// 2.将输入流对象进行解析 得到workbook对象
Workbook workbook = new XSSFWorkbook(in)) {
// 3.workbook中有几个工作簿
int sheetNum = workbook.getNumberOfSheets();
System.out.println("一共有" + sheetNum + "个工作簿");
// 3.1通过workbook 创建工作簿对象
Sheet sheet1 = workbook.getSheet("Sheet0");
Sheet sheet2 = workbook.getSheetAt(1);
// 3.2工作簿中有几条数据
System.out.println("sheet1一共有:" + sheet1.getLastRowNum() + "条数据");
System.out.println("sheet2一共有:" + sheet2.getLastRowNum() + "条数据");
// 4.通过Sheet对象创建行对象
Row row = sheet1.getRow(1);
// 5.通过Row对象创建单元格对象
Cell cell = row.getCell(1);
二、读、写Excel文件的数据
1.读取文件
1.常用方法
1.创建Sheet对象有两种方式:
①通过下标 getSheetAt()方法、②通过sheet名称getSheet(“表名称”)
2.获取工作簿的个数:getNumberOfSheets()方法
3.获取Sheet中的数据数目:getNumberOfSheets()方法
4.获取Row中的单元格数目:getLastCellNum()方法
5.获取单元格数据之前,要进行数据类的判断:getCellType()方法
6.获取单元格数据为字符串:getStringCellValue()方法
7.获取单元格数据为数值:getNumericCellValue()方法
2.代码实现
代码如下:
try (Workbook workBook = new XSSFWorkbook(