poi导出大量数据excel内存溢出解决方案

Excel2003版最大行数是65536行。Excel2007开始的版本最大行数是1048576行。

Excel2003的最大列数是256列,2007以上版本是16384列。

 

poi导出excel,不使用模板的

http://happyqing.iteye.com/blog/2075985

 

xls格式导出使用HSSFWorkbook,(这个暂时没有好办法)

 

xlsx格式导出以前使用XSSFWorkbook,可以使用新的SXSSFWorkbook(poi3.8+)

 

Workbook wb = new SXSSFWorkbook(1000); //大于1000行时会把之前的行写入硬盘

 

Row,Cell还跟之前的一样

 

官方样例

http://poi.apache.org/spreadsheet/how-to.html#sxssf

Java代码   收藏代码
  1. import junit.framework.Assert;  
  2. import org.apache.poi.ss.usermodel.Cell;  
  3. import org.apache.poi.ss.usermodel.Row;  
  4. import org.apache.poi.ss.usermodel.Sheet;  
  5. import org.apache.poi.ss.usermodel.Workbook;  
  6. import org.apache.poi.ss.util.CellReference;  
  7. import org.apache.poi.xssf.streaming.SXSSFWorkbook;  
  8.   
  9.     public static void main(String[] args) throws Throwable {  
  10.         SXSSFWorkbook wb = new SXSSFWorkbook(100); // keep 100 rows in memory, exceeding rows will be flushed to disk  
  11.         Sheet sh = wb.createSheet();  
  12.         for(int rownum = 0; rownum < 1000; rownum++){  
  13.             Row row = sh.createRow(rownum);  
  14.             for(int cellnum = 0; cellnum < 10; cellnum++){  
  15.                 Cell cell = row.createCell(cellnum);  
  16.                 String address = new CellReference(cell).formatAsString();  
  17.                 cell.setCellValue(address);  
  18.             }  
  19.   
  20.         }  
  21.   
  22.         // Rows with rownum < 900 are flushed and not accessible  
  23.         for(int rownum = 0; rownum < 900; rownum++){  
  24.           Assert.assertNull(sh.getRow(rownum));  
  25.         }  
  26.   
  27.         // ther last 100 rows are still in memory  
  28.         for(int rownum = 900; rownum < 1000; rownum++){  
  29.             Assert.assertNotNull(sh.getRow(rownum));  
  30.         }  
  31.           
  32.         FileOutputStream out = new FileOutputStream("/temp/sxssf.xlsx");  
  33.         wb.write(out);  
  34.         out.close();  
  35.   
  36.         // dispose of temporary files backing this workbook on disk  
  37.         wb.dispose();  
  38.     }  

 

 值得注意的是SXSSFWorkbook只能写不能读。但是往往我们需要向一个Excel模版里导出数据,这样才更好提前定义里面的格式和vba代码。

这里就需要使用SXSSFWorkbook的另外一个构造函数:

SXSSFWorkbook(XSSFWorkbook workbook)
Construct a workbook from a template.

 通过XSSFWorkbook来读取模版,然后用SXSSFWorkbook来设置样式和写数据,详细使用就参考API吧。 http://poi.apache.org/apidocs/org/apache/poi/xssf/streaming/SXSSFWorkbook.html


推荐另一种生成excel的方法。用pageoffice生成excel。pageoffice设计的还是很方便的,很多接口函数。比poi生成excel简单。最主要的是可以在线打开 ,编辑, 保存文档。还可以在线操作word,ppt等办公文档。

猜你喜欢

转载自blog.csdn.net/zwj1030711290/article/details/80853009