JavaWEB--POI之EXCEL操作、优化、封装详解系列(六)--PoiExportUtil使用文档(2)分页

前面的方法已经可以应对我们业务开发的大部分情况了,但是当导出年份报表的时候,这就涉及大量的数据的查询到对象里。如果是几百个字段而且是几万条数据,查询到一个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的博客

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,475评论 4 372
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,744评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 112,101评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,732评论 0 221
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,141评论 3 297
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,049评论 1 226
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,188评论 2 320
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,965评论 0 213
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,716评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,867评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,341评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,663评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,376评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,200评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,990评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,179评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,979评论 2 279

推荐阅读更多精彩内容