JavaWEB--POI之EXCEL操作、优化、封装详解系列(六)--PoiExportUtil使用文档(2)分页
来源:互联网 发布:淘宝天猫店铺怎么申请 编辑:程序博客网 时间:2024/06/06 05:52
前面的方法已经可以应对我们业务开发的大部分情况了,但是当导出年份报表的时候,这就涉及大量的数据的查询到对象里。如果是几百个字段而且是几万条数据,查询到一个list里面?这明显不现实,而且对于内存是极大的压力,极有可能内存溢出。这个时候,分页是非常棒的解决方案。
文章结构:(1)PoiExportUtil面向JavaBean的分页;(2)PoiExportUtil面向List-Map结构的分页;
一、PoiExportUtil面向JavaBean的分页:
(一)设计思路:
(1)兼容普通JavaBean;
(2)更自由地去控制分页
(3)模块化(可以多表格)
(4)接口方法易用性;
(5)导出数据准确性;
(6)扩展性。
(二)使用步骤:
(1)传入想要的EXCEL版本,调用getPageExcelBook(int excelVersion)方法拿到工作簿对象
(2)传入表格的title,调用getPageExcelSheet(Workbook wb,String bookTitle);拿到表格对象
(3)传入标题栏对应的数据,调用exportPageTitleExcel(Workbook wb,Sheet sheet,List–headersName,StyleInterface styleUtil);方法
(4)针对JavaBean结构传入数据,调用exportPageContentBeanExcel方法。
此方法有两种选择。可以直接导出全部数据,可以根据headersId导出想要的字段。
(3)调用代码:
package com.fuzhu.test;import com.fuzhu.base.PoiExcelBase;import com.fuzhu.base.PoiInterface;import com.fuzhu.base.StyleInterface;import com.fuzhu.model.Student;import com.fuzhu.styleImpl.MyStyle;import com.fuzhu.util.PoiBeanFactory;import org.apache.poi.ss.usermodel.Sheet;import org.apache.poi.ss.usermodel.Workbook;import java.io.FileOutputStream;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;/** * Created by 符柱成 on 2017/8/25. */public class ExportPageBeanTest { public static void main(String [] args) throws Exception { List<String> listName = new ArrayList<>(); listName.add("id"); listName.add("名字"); listName.add("性别"); List<String> listId = new ArrayList<>(); listId.add("id"); listId.add("name"); listId.add("sex"); FileOutputStream exportXls = null; if (PoiExcelBase.EXCEL_VERSION_07==0) { exportXls = new FileOutputStream("E://工单信息表PageNoHeaders.xls"); }else { exportXls = new FileOutputStream("E://工单信息表PageNoHeaders.xlsx"); } /* (一)去工厂拿导出工具 */ PoiInterface<Student> poiInterface = PoiBeanFactory.getInstance().getPoiUtil(PoiExcelBase.EXPORT_SIMPLE_EXCEL); /* (二)拿到工作簿对象(可选版本) */ Workbook workbook = poiInterface.getPageExcelBook(PoiExcelBase.EXCEL_VERSION_07); /* (三)拿到表格对象(填写表格名字) */ Sheet sheet = poiInterface.getPageExcelSheet(workbook,"测试工作簿的title"); /* (四)自定义样式 */ StyleInterface myStyle = new MyStyle(); /* (五)导出标题栏数据先 */ sheet = poiInterface.exportPageTitleExcel(workbook,sheet,listName,myStyle); /* (六)分页导出数据列(注意控制好页码以及一页的数量--做过分页功能的应该都有这个经验的) */ int q=0; for (int t =1;t<6;t++){ List<Student> list = new ArrayList<>(); list.add(new Student(++q,"张三asdf","男"+t)); list.add(new Student(++q,"李四asd","男"+t)); list.add(new Student(++q,"王五bhasdcfvbhujidsaub","女"+t)); //默认导出全部数据 poiInterface.exportPageContentBeanExcel(workbook,sheet,list,myStyle,t,3); //根据listId(也就是headersId)导出数据 //poiInterface.exportPageContentBeanExcel(workbook,sheet,listId,list,myStyle,t,3); } /* (七)写入到流对象 */ workbook.write(exportXls); exportXls.close(); }}
(4)调用说明:
刚刚说到有两种选择路线。一、导出全部数据;二、根据headersId导出想要的字段。
设计缘由:据网友反映,他们有时候是自己规范好了导出的数据,所以不需要再度去筛选。所以本博主封装了两条路线。
数据导出顺序是:JavaBean的属性顺序
二、PoiExportUtil面向List-Map结构的分页:
(一)设计思路:
(1)兼容普通List-Map结构;
(2)更自由地去控制分页
(3)模块化(可以多表格)
(4)接口方法易用性;
(5)导出数据准确性;
(6)扩展性。
(二)使用步骤:
(1)传入想要的EXCEL版本,调用getPageExcelBook(int excelVersion)方法拿到工作簿对象
(2)传入表格的title,调用getPageExcelSheet(Workbook wb,String bookTitle);拿到表格对象
(3)传入标题栏对应的数据,调用exportPageTitleExcel(Workbook wb,Sheet sheet,List–headersName,StyleInterface styleUtil);方法
(4)针对List-Map结构传入数据,调用exportPageContentMapExcel方法。
此方法有两种选择。可以直接导出全部数据,可以根据headersId导出想要的字段。
(3)调用代码:
package com.fuzhu.test;import com.fuzhu.base.PoiExcelBase;import com.fuzhu.base.PoiInterface;import com.fuzhu.base.StyleInterface;import com.fuzhu.model.Student;import com.fuzhu.styleImpl.MyStyle;import com.fuzhu.util.PoiBeanFactory;import java.io.FileOutputStream;import java.util.*;/** * Created by 符柱成 on 2017/8/25. */public class ExportMapTest { public static void main(String [] args) throws Exception { List<String> listName = new ArrayList<>(); listName.add("id"); listName.add("名字"); listName.add("性别"); List<String> listId = new ArrayList<>(); listId.add("id"); listId.add("sex"); listId.add("name"); List<Map<String,Object>> listB = new ArrayList<>(); for (int t=0;t<6;t++){ Map<String,Object> map = new TreeMap<>();//使用了TreeMap保证加入到容器时是有序的 map.put("id",t); map.put("name","abc"+t); map.put("sex","男"+t); listB.add(map); } FileOutputStream exportXls = null; if (PoiExcelBase.EXCEL_VERSION_07==0) { exportXls = new FileOutputStream("E://工单信息表Map.xls"); }else { exportXls = new FileOutputStream("E://工单信息表Map.xlsx"); } /* (一)去工厂拿导出工具 */ PoiInterface<Student> poiInterface = PoiBeanFactory.getInstance().getPoiUtil(PoiExcelBase.EXPORT_MAP_EXCEL); /* (二)自定义样式(可无) */ StyleInterface myStyle = new MyStyle(); /* (三)根据需求选择接口方法(返回码:1是成功,0为失败) */ //导出默认样式的Map结构Excel--根据headersId筛选要导出的字段 //int flag = poiInterface.exportMapExcel(PoiExcelBase.EXCEL_VERSION_07,"测试POI导出EXCEL文档",listName,listId,listB,exportXls); //导出自定义样式的Map结构Excel--根据headersId筛选要导出的字段 //int flag = poiInterface.exportStyleMapExcel(PoiExcelBase.EXCEL_VERSION_07,"测试POI导出EXCEL文档",listName,listId,listB,exportXls,myStyle); //导出自定义样式的Map结构Excel--没有标题栏字段匹配,数据体dtoList需要使用treemap。--默认导出dtolist的所有数据 int flag = poiInterface.exportStyleMapExcel(PoiExcelBase.EXCEL_VERSION_07,"测试POI导出EXCEL文档",listName,listB,exportXls,myStyle); System.out.println("flag : "+flag); exportXls.close(); }}
(4)调用说明:
刚刚说到有两种选择路线。一、导出全部数据;二、根据headersId导出想要的字段。
设计缘由:据网友反映,他们有时候是自己规范好了导出的数据,所以不需要再度去筛选。所以本博主封装了两条路线。
数据导出顺序是:无序的。
解决方案:使用TreeMap,使数据加入到容器的时候就是有序的–对应dtoList。这样导出也就是有序了的。
POI辅助库PoiExportUtil源码下载:JavaWEB–POI之EXCEL操作、优化、封装详解系列(五)–PoiExportUtil使用文档(2)分页
好了,JavaWEB–POI之EXCEL操作、优化、封装详解系列(五)–PoiExportUtil使用文档(2)分页讲完了,这是自己设计的第一个Java工具库,在这里写出来记录,这是积累的必经一步,我会继续出这个系列文章,分享经验给大家。欢迎在下面指出错误,共同学习!!你的点赞是对我最好的支持!!
更多内容,可以访问JackFrost的博客
阅读全文
0 0
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(六)--PoiExportUtil使用文档(2)分页
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(五)--PoiExportUtil使用文档(1)
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(三)--万能POI之EXCEL导出工具--PoiExportUtil入门篇
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(四)--PoiExportUtil架构设计篇与功能说明
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(一)--概述与原理
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(二)--导入导出helloworld(对比JXL库)
- POI操作Excel文档(一)
- POI操作Excel文档(二)
- POI操作Excel文档(三)
- 使用POI组件操作Excel文档
- Java导出Excel文档使用poi操作
- POI操作Excel文档
- POI 操作Excel文档
- POI操纵EXCEL文档之导入文档(一)
- (二) POI 解析Excel 之 生成Excel文档
- (三) POI 解析Excel 之 读取Excel 文档
- Javaweb操作Excel文档
- 使用POI操作Excel文件(一)
- springmvc多个拦截器中拦截器方法的执行顺序
- 【数据结构专题-02】算法介绍
- 05:输出保留12位小数的浮点数
- JavaScript
- OSG 视图与相机 类图
- JavaWEB--POI之EXCEL操作、优化、封装详解系列(六)--PoiExportUtil使用文档(2)分页
- mysql encode&decode
- Javaweb核心之el&jstl
- 关于学习算法的一个辅助工具 Metacademy
- The Snail
- spark本地读取写入s3文件
- cifar-10 分类 tensorflow 代码
- 使用命令行运行JMeter脚本
- Android初级开发(八)——手机多媒体—底部弹窗+选择照片或拍照的实现