Excel文件解析

在应用程序的开发过程中,经常需要使用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;
      }
}

  • 14
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值