java poi在导出数据到excel2003工作表中时一个工作表只能存储65536行数据,如果超过这个数据就会失败,excel2007并没有这个问题,但是为了兼容性我们通常都是导出到2003版本上的。

1、导出成xlsx格式。

2、达到某个数值就再创建一张工作表。

    /**
* 如果达到50000条数据则重新创建工作表的逻辑
*/
@Override
public void exportExcel(List<HolidayItemForm> formList, ServletOutputStream outputStream){
try {
//工作表名后面的数字,如表1,表2
int i = 0;
//记录总行数
int rownum = 0;
//记录每个sheet的行数
int tempnum = 0;
//分页条数达到此条数则创建工作表
int page = 5;
//创建工作薄
HSSFWorkbook workbook = new HSSFWorkbook();
//创建列标题栏样式
HSSFCellStyle cellStyle = ExcelUtils.createCellStyle(workbook, (short)10);
while(true){
//创建工作表并应用上面的样式
HSSFSheet sheet = ExcelUtils.createWorkbook(workbook,cellStyle,++i);
rownum++;
//将数据库中的数据列表写入excel中
if(formList != null){
tempnum = 0;
for (int j=rownum-i; j<formList.size(); j++) {
//进入第2个sheet写出的行数从第2条数据开始(++tempnum等于1,因为标题行占了1行)
HSSFRow row2 = sheet.createRow(++tempnum);
rownum++;
row2.createCell(0).setCellValue(formList.get(j).getUserId());
row2.createCell(1).setCellValue(formList.get(j).getUserName());
row2.createCell(2).setCellValue(formList.get(j).getDeptName());
row2.createCell(3).setCellValue(formList.get(j).getUserJob());
row2.createCell(4).setCellValue(formList.get(j).getTypeName());
row2.createCell(5).setCellValue(formList.get(j).getBeginDate());
row2.createCell(6).setCellValue(formList.get(j).getEndDate());
row2.createCell(7).setCellValue(formList.get(j).getHolidayHour());
row2.createCell(8).setCellValue(formList.get(j).getCreateDate());
//达到5条退出并创建另外一个sheet
if(rownum%page == 0){
break;
}
}
}
//如果记录的行数等于集合的总行数则退出
if((rownum-i) == formList.size()){
break;
}
}
//输出
workbook.write(outputStream);
workbook.close();
} catch (IOException e) {
e.printStackTrace();
}
}

参考:https://blog.csdn.net/wjycgl/article/details/53942818

解决java poi导出excel2003不能超过65536行的问题的更多相关文章

  1. 解决Java POI 导出Excel时文件名中文乱码,兼容浏览器

    String agent = request.getHeader("USER-AGENT").toLowerCase(); response.setContentType(&quo ...

  2. 重构:以Java POI 导出EXCEL为例

    重构 开头先抛出几个问题吧,这几个问题也是<重构:改善既有代码的设计>这本书第2章的问题. 什么是重构? 为什么要重构? 什么时候要重构? 接下来就从这几个问题出发,通过这几个问题来系统的 ...

  3. Java POI 导出EXCEL经典实现 Java导出Excel

    转自http://blog.csdn.net/evangel_z/article/details/7332535 在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者 ...

  4. 解决Android单个dex文件不能超过65536个方法问题

    当我们的项目代码过大时,编译运行时会报Unable to execute dex: method ID not in[0, 0xffff]: 65536)错误.当出现这个错误时说明你本身自己的工程代码 ...

  5. 重构:以Java POI 导出EXCEL为例2

    前言 上一篇博文已经将一些对象抽象成成员变量以及将一些代码块提炼成函数.这一节将会继续重构原有的代码,将一些函数抽象成类,增加成员变量,将传入的参数合成类等等. 上一篇博文地址:http://www. ...

  6. java poi导出多sheet页

    /** * @Title: exportExcel * @Description: 导出Excel的方法 * @param workbook * @param sheetNum (sheet的位置,0 ...

  7. 复杂的POI导出Excel表格(多行表头、合并单元格)

    poi导出excel有两种方式: 第一种:从无到有的创建整个excel,通过HSSFWorkbook,HSSFSheet HSSFCell, 等对象一步一步的创建出工作簿,sheet,和单元格,并添加 ...

  8. Pandas 读取超过 65536 行的 Excel 文件

    Excel 文件的格式曾经发生过一次变化,在 Excel 2007 以前,使用扩展名为 .xls 格式的文件,这种文件格式是一种特定的二进制格式,最多支持 65,536 行,256 列表格.从 Exc ...

  9. java:POI导出excel

    POI是一个开源项目,专用于java平台上操作MS OFFICE,企业应用开发中可用它方便导出Excel. 下面是使用示例: 1.maven中先添加依赖项 <dependency> < ...

随机推荐

  1. iOS多线程知识梳理

    iOS多线程知识梳理 线程进程基础概念 进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 线程 1个进程要想执行任务,必须得有线程(每1个 ...

  2. Assets.xcassets:-1: Failed to find a suitable device for the type IBSimDeviceTypeiPad2x

    Assets.xcassets:-1: Failed to find a suitable device for the type IBSimDeviceTypeiPad2x 不知道assets发生了 ...

  3. steamdb cookie

    steamdb cookie import requests, re, os, pymysql, time from lxml import etree from steamdb.YDM import ...

  4. [译]Vulkan教程(30)深度缓存

    [译]Vulkan教程(30)深度缓存 Depth buffering 深度缓存 Introduction 入门 The geometry we've worked with so far is pr ...

  5. Navicat Premium连接mongodb基本使用和介绍

    Navicat premium是一款数据库管理工具,是一个可多重连线资料库的管理工具, 它可以让你以单一程式同时连线到 MySQL.SQLite.Oracle 及 PostgreSQL,mongodb ...

  6. IT兄弟连 HTML5教程 CSS3揭秘 CSS常见的样式属性和值5

    CSS综合实例 在Web页面中经常使用栏目显示分类内容.本例将使用HTML和CSS结合编写一个分类栏目模型,用于演示前面介绍的CSS应用.通过使用独立的文件定义样式表,并在HTML文档中使用link标 ...

  7. MySQL数据以全量和增量方式,同步到ES搜索引擎

    本文源码:GitHub·点这里 || GitEE·点这里 一.配置详解 场景描述:MySQL数据表以全量和增量的方式向ElasticSearch搜索引擎同步. 1.下载内容 elasticsearch ...

  8. 【Luogu P3994】高速公路

    Problem Background \(C\) 国拥有一张四通八达的高速公路网树,其中有 \(n\) 个城市,城市之间由一共 \(n-1\) 条高速公路连接.除了首都 \(1\) 号城市,每个城市都 ...

  9. Android中的常用控件之进度条(ProgressBar)

    ProgressBar的常用属性:style,进度条的样式,默认为圆形,用style="?android:attr/progressBarStyleHorizontal"可以将进度 ...

  10. windows平台多网卡设置路由

    添加路由命令: route add 192.168.4.0 mask 255.255.255.0 192.168.4.1 metric 20 if 11 -p 其中192.168.4.0 是网络目标, ...