yekui / excel-eventpoi

excel 导入导出(事件流poi处理工具)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

高性能事件驱动 eventpoi 支持poi4.x以上

功能介绍

  • 支持 【功能】 支持代码内置的四舍五入公式,如divideRound(list.age,3,2)对age除以3之后再按四舍五入保留两位小数
  • 支持 【功能】 支持保留小数(不四舍五入),如${divideTruncate(list.age,3,2)}对age除以3之后保留两位小数,不四舍五入
  • 支持 【功能】 支持[自定义]导出公式,如${myAdd(list.age,1)},表示为取导出年龄字段,并加1,如果list.age为空,则参考MyAddFunction类处理,会自动把空转为0再加1。因此自定义函数,是一项非常重要的方式,在处理导出excel时,如处理导出Date时间字段,按那种格式(yyyyMMdd)导出
  • 支持 【功能】 【读取excel/导入】excel文件高性能读取 并自动转java对象,只需一行代码
  • 支持 【功能】 支持导出表格形式的excel文件,和列表excel文件
  • 支持 【功能】 【图片导入和导出】支持图片列和文本混合列形式的excel导入
  • 支持 【功能】 【行回调异步处理】边读边处理,无须等待excel全部解析。
  • 支持 【功能】 自动识别xls文件和xlsx文件格式
  • 支持 【功能】 复杂的表格导出,既包含【列表形式】的数据 也包含【表单形式】的数据导出(查看 "测试包含表格和列表数据的复杂导出.java" 文件)
  • 支持 【特性】 使用事件驱动方式读取excel,无行数和内存限制。
  • 支持 【特性】 高性能,导出10w行数据,需3s
  • 支持 【案例】 查看src/test/java目录

使用注意事项

  • 导出复杂结构的excel时,模板内容 除了${xxxx}占位符之外,禁止${符号的内容再出现,原因是程序目前只按${解析模板
    • 后期可优化为用户指定占位符
  • 所有占位符不可重复
  • 导入图片,或者 导出图片 时,java对象中的属性要是byte[]类型,如private byte[] headIamge;

有使用问题,请提交issues,或者加QQ群591170125反馈

使用案例见/eventpoi/src/test/java目录

新建模板excel文件

image

使用一行代码读取excel

public class 使用行代码读取excel {
    public static void main(String[] args) throws Exception {
        List<Person> objList = ExcelHelper.parseExcelToObject(Test1.class.getResourceAsStream("demo1.xlsx"), Test1.class.getResourceAsStream("demo1Templete.xlsx"), Person.class);
        System.err.println(JSON.toJSONString(objList,true));
    }
}

使用一行代码导出excel

public class 使用行代码导出excel {
    public static void main(String[] args) throws Exception {
        List<Person> personList = new ArrayList<Person>();
        Person p1 = new Person();
        p1.setAge(11);
        p1.setName("ssssss111");
        p1.setRemark("测试测试啊remark111");
        
        Person p2 = new Person();
        p2.setAge(22);
        p2.setName("ssssss222");
        p2.setRemark("测试测试啊remark2222");
        personList.add(p1);
        personList.add(p2);
        
        byte[] exportByteData = ExcelHelper.exportExcel(Test1.class.getResourceAsStream("demo1Templete.xlsx"), personList, "${salary}");
        Files.write(Paths.get("./my_test_temp/测试导出指定对象并删除指定列.xlsx"), exportByteData);
    }
}

复杂结构的excel导出(都在src/test/java中 测试包含表格和列表数据的复杂导出.java),如图

image

excel模板 ./my_test_temp/测试包含表格和列表数据的复杂导出.xlsx

public class 测试包含表格和列表数据的复杂导出 {
    public static void main(String[] args) throws Exception {
    	//构造表格形式的数据
    	OrderInfo orderInfo = new OrderInfo();
    	orderInfo.setKehu("ddddcccc");
    	orderInfo.setOrderName("进口海鲜");
    	orderInfo.setTotalMoney("15.66");
    	orderInfo.setBuyer("张三");
    	orderInfo.setSaller("李四");
    	
    	//构造列表形式的数据
        List<Object>  excelDataList = new ArrayList<Object>();
        List<ProductInfo> productList = new ArrayList<ProductInfo>();
        ProductInfo p1 = new ProductInfo();
        p1.setNo("NO_1");
        p1.setName("ssssss111");
        
        ProductInfo p2 = new ProductInfo();
        p2.setNo("NO_2");
        p2.setName("ssssss222");
        
        ProductInfo p3 = new ProductInfo();
        p3.setNo("NO_3");
        p3.setName("ssssss333");
        
        productList.add(p1);
        productList.add(p2);
        productList.add(p3);
        
        excelDataList.add(productList);
        excelDataList.add(orderInfo);

        byte[] exportByteData = ExcelHelper.exportTableExcel(Test1.class.getResourceAsStream("订单_templete.xlsx"), excelDataList);
        Files.write(Paths.get("./my_test_temp/测试包含表格和列表数据的复杂导出.xlsx"), exportByteData);
    }
}

About

excel 导入导出(事件流poi处理工具)

License:Apache License 2.0


Languages

Language:Java 100.0%