Java使用POI導(dǎo)出大數(shù)據(jù)量Excel的方法
今天需要寫一個(gè)導(dǎo)出的Excel的功能,但是發(fā)現(xiàn)當(dāng)數(shù)據(jù)量到3萬(wàn)條時(shí),列數(shù)在23列時(shí),內(nèi)存溢出,CPU使用100%,測(cè)試環(huán)境直接炸掉。在本地測(cè)試時(shí)發(fā)現(xiàn),導(dǎo)出3000條左右的數(shù)據(jù)的時(shí)候,堆內(nèi)存瞬間升高500M左右。然后發(fā)現(xiàn)了 SXSSFWorkbook 這個(gè)類。
簡(jiǎn)介
SXSSFWorkbook 需要 poi-ooxml 包 3.8 及以上開(kāi)始支持,我這邊適使用的是 3.9 版本,本質(zhì)是一個(gè) XSSFWorkbook 類( Excel2007 ),它使用的方式是采用 硬盤空間 來(lái)大幅降低 堆內(nèi)存 的占用,在系統(tǒng)的臨時(shí)文件夾目錄創(chuàng)建一個(gè)臨時(shí)文件,然后將所有大于約定行數(shù)的數(shù)據(jù)都存入臨時(shí)文件,而不是全部放在內(nèi)存中,內(nèi)存中只存放 最新的 的約定條數(shù)的數(shù)據(jù),從而實(shí)現(xiàn)以硬盤空間換取內(nèi)存空間,避免內(nèi)存溢出
使用方式
與正常的Excel導(dǎo)出方法沒(méi)有區(qū)別,只是將實(shí)例化的類換為 SXSSFWorkbook
SXSSFWorkbook workbook = null; OutputStream outputStream = null; try { outputStream = response.getOutputStream(); //創(chuàng)建工作簿 workbook = new SXSSFWorkbook(); // 打開(kāi)壓縮功能 防止占用過(guò)多磁盤 workbook.setCompressTempFiles(true); // 創(chuàng)建一個(gè)工作表 Sheet sheet = workbook.createSheet("表名"); // 創(chuàng)建一行 Row titleRow = sheet.createRow(0); // 創(chuàng)建一個(gè)單元格 Cell cell = titleRow.createCell(0); // 給單元格賦值 cell.setCellValue("內(nèi)容"); // 將工作簿寫入輸出流 workbook.write(outputStream); } catch (Exception e) { e.printStackTrace(); }finally { if (workbook != null) { //使用完畢后將產(chǎn)生的臨時(shí)文件刪除 防止將磁盤搞滿 workbook.dispose(); } if (outputStream != null) { outputStream.close(); } }
總結(jié)
以上所述是小編給大家介紹的Java使用POI導(dǎo)出大數(shù)據(jù)量Excel的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- Java利用POI實(shí)現(xiàn)導(dǎo)入導(dǎo)出Excel表格示例代碼
- java poi導(dǎo)出圖片到excel示例代碼
- Java使用POI實(shí)現(xiàn)導(dǎo)出Excel的方法詳解
- Java使用poi組件導(dǎo)出Excel格式數(shù)據(jù)
- Java中利用POI優(yōu)雅的導(dǎo)出Excel文件詳解
- Java Web使用POI導(dǎo)出Excel的方法詳解
- Java中用POI實(shí)現(xiàn)將數(shù)據(jù)導(dǎo)出到Excel
- java poi導(dǎo)出excel時(shí)如何設(shè)置手動(dòng)換行
- Java使用Poi導(dǎo)出Excel表格方法實(shí)例
相關(guān)文章
iOS socket網(wǎng)絡(luò)編程實(shí)例詳解
socket是一個(gè)針對(duì)TCP和UDP編程的接口,你可以借助它建立TCP連接等。這篇文章主要介紹了iOS socket網(wǎng)絡(luò)編程 ,需要的朋友可以參考下2017-03-03詳談Java靜態(tài)動(dòng)態(tài)的問(wèn)題
下面小編就為大家?guī)?lái)一篇詳談Java靜態(tài)動(dòng)態(tài)的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09Java for-each循環(huán)使用難題2例(高級(jí)使用方法)
從Java5起,在Java中有了for-each循環(huán),可以用來(lái)循環(huán)遍歷collection和array。For each循環(huán)允許你在無(wú)需保持傳統(tǒng)for循環(huán)中的索引,或在使用iterator /ListIterator時(shí)無(wú)需調(diào)用while循環(huán)中的hasNext()方法就能遍歷collection2014-04-04java swing實(shí)現(xiàn)簡(jiǎn)單計(jì)算器界面
這篇文章主要為大家詳細(xì)介紹了java swing實(shí)現(xiàn)簡(jiǎn)單計(jì)算器界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04Jmeter測(cè)試時(shí)遇到的各種亂碼問(wèn)題及解決
這篇文章主要介紹了Jmeter測(cè)試時(shí)遇到的各種亂碼問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03java開(kāi)發(fā)validate方法中校驗(yàn)工具類詳解
這篇文章主要為大家介紹了java開(kāi)發(fā)validate方法中校驗(yàn)工具類詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09java開(kāi)發(fā)技巧代碼寫的快且bug少的原因分析
這篇文章主要為大家介紹了java開(kāi)發(fā)中代碼寫的快且bug少的原因分析及技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12