美文网首页
java导出讲解以及效率对比(代码演示)

java导出讲解以及效率对比(代码演示)

作者: 你可以叫我老白 | 来源:发表于2022-04-06 10:26 被阅读0次

在之前我们知道处理xls的excel用的workbook是HSSFWorkbook,处理xlsx的excel用的是XSSFWorkbook。

1、SXSSFWorkbook是在POI3.8版本开始提供基于XSSF低内存占用的SXSSF

SXSSF通过一个滑动窗口来限制访问Row的数量从而达到低内存占用的目录,XSSF可以访问所有行。SXSSF通过设置rowAccessWindowSize的大小实现滑动窗口中存储数据量的row数量,当行数超过滑动窗口设定的值时,此时旧的数据不再出现在滑动窗口且不可对此进行

访问,同时将此数据写入磁盘。也可通过flushRow(int keepRows)设定行数通过周期性的调用来修改。

注意:针对 SXSSF Beta 3.8下,会有临时文件产生,比如: 

poi-sxssf-sheet4654655121378979321.xml 

文件位置:java.io.tmpdir这个环境变量下的位置 

Windows 7下是C:UsersxxxxxAppDataLocalTemp 

Linux下是 /var/tmp/ 

2、当数据量超出65536条后,在使用HSSFWorkbook或XSSFWorkbook,程序会报OutOfMemoryError:Javaheap space;内存溢出错误。这时应该用SXSSFworkbook

3.SXFFSWoorkbook导出的excel相比于XSSFWoorkbook导出的更节省空间:

4.测试HSSF\XSSF导出的数据占用内存,而SXFFS导出的数据不容易造成内存溢出,数据改为5万条并且写入之后查看内存信息:

public static void main(String[] args) {

        String[] title ={ "id", "name", "sex" };

        // 创建一个工作簿

        Workbook workbook =new XSSFWorkbook();

        // 创建一个工作表sheet

        Sheet sheet =workbook.createSheet();

        // 创建第一行

        Row row =sheet.createRow(0);

        // 创建一个单元格

        Cell cell =null;

        // 创建表头

        for (int i =0; i

            cell =row.createCell(i);

            cell.setCellValue(title[i]);

        }

        // 从第二行开始追加数据

        for (int i =1; i <=50000; i++) {

            // 创建第i行

            Row nextRow =sheet.createRow(i);

            // 参数代表第几列

            Cell cell2 =nextRow.createCell(0);

            cell2.setCellValue("a" +i);

            cell2 =nextRow.createCell(1);

            cell2.setCellValue("user" +i);

            cell2 =nextRow.createCell(2);

            cell2.setCellValue("男");

        }

        // 创建一个文件

        File file =new File("C:/Users/YZS/Desktop/常用/tt1.xls");

        try {

            file.createNewFile();

            // 打开文件流

            FileOutputStream outputStream =new FileOutputStream(file);

            workbook.write(outputStream);

            outputStream.close();

            // dispose of temporary files backing this workbook on disk

//            ((SXSSFWorkbook) workbook).dispose();

            System.out.println("创建完成");

            System.out.println("总的内存->" +Runtime.getRuntime().totalMemory() /1024 /1024 +"MB");

            System.out.println("剩余的内存->" +Runtime.getRuntime().freeMemory() /1024 /1024 +"MB");

        } catch (Exception e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

将上面XSSF改为SXFFS查看结果

相关文章

网友评论

      本文标题:java导出讲解以及效率对比(代码演示)

      本文链接:https://www.haomeiwen.com/subject/mutdsrtx.html