在应用程序的开发过程中,经常需要使用Excel文件来进行数据的导入或导出,Apache POI 基于DOM方式进行解析,将文件直接加载内存,速度较快,适合excel文件数据量不打的应用场景。
Workbook接口代表一个Excel文件,用于创建或解析Excel文件,常见的实现类XSSFWorkbook.
创建Excel文件
try(Workbook workbook = new XSSFWorkbook();
FileOutputStream da = new FileOutputStream("F:\\java.xlsx")){
workbook.write(da);
}catch (IOException e){
e.printStackTrace();
}
)
解析Excel文件
//输入流
FileInputStream da = new FileInputStream("c:\\java.xlsx");
//Excel文件对象
Workbook workbook = new XSSFWorkbook(da);
Sheet(工作簿)
创建工作簿
//按照默认名称创建工作簿
Sheet sheet = workbook.createSheet();
//按照自定义名称创建工作簿
Sheet sheet1 = workbook.createSheet("自定义");
//获取工作簿的数量
int n = workbook.getNumberOfSheets();
//创建数据行(通过Sheet进行数据行Row对象的获取和创建)
Row row = sheet.createRow(0);
//获取首行下标
int first = sheet.getFirstRowNum();
//获取尾行下标
int last = sheet.getLastRowNum();
//通过下标获取指定行
Row row = sheet.getRow(0);
//遍历所有行
for(Row row : sheet){
System.out.println(row);
}
//遍历指定区域行
for(int i = 1; i <= sheet.getLastRowNum();i++){
Row row = sheet.getRow(i);
System.out.println(row);
}
超大Excel文件的读写
1:在进行超大文件的读写时可以使用SXXSFWorkbook进行写入,通过设置SXXSFWorkbook的构造参数,设置每次在内存中保存的行数,当达到这个值时就会把这些数据flush到磁盘。
2:使用EasyExcel
写入数据
public class Da{
public static void main(String[] args){
//写入100W
EasyExcel.write("F:\\zuoye\\easy.xlsx,Order.class")
.sheet("订单列表")
.doWrite(data());
}
//创建100w条订单
private static List<Order> data(){
List<Order> list = new ArrayList<Order>();
for(int i = 0;i < 1000000;i++){
list.add(new Order());
}
return list;
}
}