poi导出excel (大数据)
2016-03-29 23:18
288 查看
POI之前的版本不支持大数据量处理 如果数据过多则经常报OOM错误,有时候调整JVM大小效果也不是太好。3.8版本的POI新出来了SXSSFWorkbook,可以支持大数据量的操作,只是SXSSFWorkbook只支持.xlsx格式,不支持.xls格式。
3.8版本的POI对excel的导出操作,一般只使用HSSFWorkbook以及SXSSFWorkbook,HSSFWorkbook用来处理较少的数据量,SXSSFWorkbook用来处理大数据量以及超大数据量的导出。
HSSFWorkbook的使用方法和之前的版本的使用方法一致,这里就不在陈述使用方法了
SXSSFWorkbook的使用例子如下:
参考:http://blog.sina.com.cn/s/blog_68555ee501015xk2.html
3.8版本的POI对excel的导出操作,一般只使用HSSFWorkbook以及SXSSFWorkbook,HSSFWorkbook用来处理较少的数据量,SXSSFWorkbook用来处理大数据量以及超大数据量的导出。
HSSFWorkbook的使用方法和之前的版本的使用方法一致,这里就不在陈述使用方法了
SXSSFWorkbook的使用例子如下:
public static void downExcel(String pathUrl) throws Exception{ File f = new File(pathUrl); FileOutputStream out = new FileOutputStream(f); Workbook workbook = new SXSSFWorkbook(); Sheet sheet = workbook.createSheet("第一页"); for (int i =0;i<1000;i++){ Row row = sheet.createRow(i); Cell cell0 = row.createCell(0); cell0.setCellValue("小时候可牛了"+i); Cell cell1 = row.createCell(1); cell1.setCellValue("小时候可帅了"+i); Cell cell2 = row.createCell(2); cell2.setCellValue("小时候可牛了"+i); Cell cell4 = row.createCell(3); cell4.setCellValue("小时候可牛了"+i); Cell cell5 = row.createCell(4); cell5.setCellValue("小时候可牛了"+i); Cell cell6 = row.createCell(5); cell6.setCellValue("小时候可牛了"+i); Cell cell7 = row.createCell(6); cell7.setCellValue("小时候可牛了"+i); } workbook.write(out); out.flush(); out.close(); workbook.close(); }
参考:http://blog.sina.com.cn/s/blog_68555ee501015xk2.html
相关文章推荐
- 使用Python生成Excel格式的图片
- Excel 曝出 Power Query 安全漏洞,1.2 亿用户易受远程 DDE 攻击
- VBA将excel数据表生成JSON文件
- excel vba 限制工作表的滚动区域代码
- excel vba 高亮显示当前行代码
- SQL 导入导出Excel数据的语句
- 文本、Excel、Access数据导入SQL Server2000的方法
- C#导出数据到Excel文件的方法
- Vbscript生成Excel报表的常用操作总结
- C#实现导入CSV文件到Excel工作簿的方法
- C#基于NPOI生成具有精确列宽行高的Excel文件的方法
- 总提示[Microsoft][ODBC Excel Driver] 数值字段溢出官方解决方法
- C#将Sql数据保存到Excel文件中的方法
- VC6.0实现读取Excel数据的方法
- C#定制Excel界面并实现与数据库交互的方法
- 把excel表格里的数据导入sql数据库的两种方法
- access dbase excel foxpro 数据库浏览器V3.1版 下载
- C#实现把txt文本数据快速读取到excel中
- C#自定义导出数据到Excel的类实例
- 使用PHPExcel操作Excel用法实例分析