Java實(shí)現(xiàn)超大Excel文件解析(XSSF,SXSSF,easyExcel)
一、XSSF
package com.yy.demo01;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.DataFormat;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public class dd {public static void main(String[] args) {
//開(kāi)始時(shí)間
long begin = System.currentTimeMillis();
try (//讀取一個(gè)已存在的Excel文件
Workbook workbook = new XSSFWorkbook(new FileInputStream("D:\\1\\demo-data.xlsx"));
FileOutputStream out = new FileOutputStream("D:\\1\\100w.xlsx")) {
//在“已存在”的Excel文件中,創(chuàng)建新的sheet
Sheet sheet = workbook.createSheet();
//獲取格式編碼值
DataFormat dataFormat = workbook.createDataFormat();
Short dateFormatCode = dataFormat.getFormat("yyyy年MM月dd日 HH:mm:ss");
Short moneyFormatCode = dataFormat.getFormat("¥#,###");
//創(chuàng)建日期格式對(duì)象
CellStyle dateCellStyle = workbook.createCellStyle();
dateCellStyle.setDataFormat(dateFormatCode);//設(shè)置格式編碼
//創(chuàng)建貨幣格式對(duì)象
CellStyle moneyCellStyle = workbook.createCellStyle();
moneyCellStyle.setDataFormat(moneyFormatCode);//設(shè)置格式編碼值
for(int i = 0; i< 300000;i++) {
String name = "A" + i;
//創(chuàng)建行
Row row = sheet.createRow(i + 1);
//創(chuàng)建單元格
Cell cell0 = row.createCell(0);//序號(hào)
cell0.setCellValue(String.valueOf(i + 1));
Cell cell1 = row.createCell(1);//姓名
cell1.setCellValue(name);
Cell cell2 = row.createCell(2);//日期
cell2.setCellStyle(dateCellStyle);//貨幣金額格式對(duì)象
cell2.setCellValue(new Date());
Cell cell3 = row.createCell(3);//紅包金額
cell3.setCellStyle(moneyCellStyle);//貨幣金額格式對(duì)象
cell3.setCellValue((int)(Math.random()*10000));
}
//寫(xiě)入文件
workbook.write(out);
//結(jié)束時(shí)間
long end = System.currentTimeMillis();
System.out.println("共耗時(shí):" +(end - begin) + "毫秒");
} catch (IOException e) {
e.printStackTrace();
}
}
}
二、SXSSF
package com.yy.demo01;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.DataFormat;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
public class Demo10 {
public static void main(String[] args) {
//開(kāi)始時(shí)間
long begin = System.currentTimeMillis();
try (//讀取一個(gè)已存在的Excel文件
Workbook workbook = new SXSSFWorkbook(100);
FileOutputStream out = new FileOutputStream("D:\\1\\100w.xlsx")) {
//在“已存在”的Excel文件中,創(chuàng)建新的sheet
Sheet sheet = workbook.createSheet();
//獲取格式編碼值
DataFormat dataFormat = workbook.createDataFormat();
Short dateFormatCode = dataFormat.getFormat("yyyy年MM月dd日 HH:mm:ss");
Short moneyFormatCode = dataFormat.getFormat("¥#,###");
//創(chuàng)建日期格式對(duì)象
CellStyle dateCellStyle = workbook.createCellStyle();
dateCellStyle.setDataFormat(dateFormatCode);//設(shè)置格式編碼
//創(chuàng)建貨幣格式對(duì)象
CellStyle moneyCellStyle = workbook.createCellStyle();
moneyCellStyle.setDataFormat(moneyFormatCode);//設(shè)置格式編碼值
for(int i = 0; i< 300000;i++) {
String name = "A" + i;
//創(chuàng)建行
Row row = sheet.createRow(i + 1);
//創(chuàng)建單元格
Cell cell0 = row.createCell(0);//序號(hào)
cell0.setCellValue(String.valueOf(i + 1));
Cell cell1 = row.createCell(1);//姓名
cell1.setCellValue(name);
Cell cell2 = row.createCell(2);//日期
cell2.setCellStyle(dateCellStyle);//貨幣金額格式對(duì)象
cell2.setCellValue(new Date());
Cell cell3 = row.createCell(3);//紅包金額
cell3.setCellStyle(moneyCellStyle);//貨幣金額格式對(duì)象
cell3.setCellValue((int)(Math.random()*10000));
}
//寫(xiě)入文件
workbook.write(out);
//結(jié)束時(shí)間
long end = System.currentTimeMillis();
System.out.println("共耗時(shí):" +(end - begin) + "毫秒");
} catch (IOException e) {
e.printStackTrace();
}
}
}
三、easyExcel
準(zhǔn)備實(shí)體類(lèi)
public class Order {
@ExcelProperty("訂單編號(hào)")
private String orderId; // 訂單編號(hào)
@ExcelProperty("支付金額")
@NumberFormat("¥#,###")
private Double payment; // 支付金額
@ExcelProperty(value = "創(chuàng)建日期",converter = LocalDateTimeConverter.class)
private LocalDateTime creationTime; // 創(chuàng)建時(shí)間
public Order() {
this.orderId = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddhhmmss"))
+ UUID.randomUUID().toString().substring(0, 5);
this.payment = Math.random() * 10000;
this.creationTime = LocalDateTime.now();
}
public String getOrderId() {
return orderId;
}
public void setOrderId(String orderId) {
this.orderId = orderId;
}
public Double getPayment() {
return payment;
}
public void setPayment(Double payment) {
this.payment = payment;
}
public LocalDateTime getCreationTime() {
return creationTime;
}
public void setCreationTime(LocalDateTime creationTime) {
this.creationTime = creationTime;
}
@Override
public String toString() {
return "Order [orderId=" + orderId + ", payment=" + payment + ", creationTime=" + creationTime + "]";
}
}
準(zhǔn)備converter轉(zhuǎn)換類(lèi)(兼容LocateDateTime日期時(shí)間類(lèi))
public class LocalDateTimeConverter implements Converter<LocalDateTime> {
@Override
public Class<LocalDateTime> supportJavaTypeKey() {
return LocalDateTime.class;
}
@Override
public CellDataTypeEnum supportExcelTypeKey() {
return CellDataTypeEnum.STRING;
}
@Override
public LocalDateTime convertToJavaData(CellData cellData, ExcelContentProperty contentProperty,
GlobalConfiguration globalConfiguration) {
return LocalDateTime.parse(cellData.getStringValue(), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
}
@Override
public CellData<String> convertToExcelData(LocalDateTime value, ExcelContentProperty contentProperty,
GlobalConfiguration globalConfiguration) {
return new CellData<>(value.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
}
}
寫(xiě)入300000條數(shù)據(jù)
public class Demo {
public static void main(String[] args) {
// 寫(xiě)入100w
EasyExcel.write("c:\\test\\run\\easy.xlsx", Order.class)
.sheet("訂單列表")
.doWrite(data());
}
// 創(chuàng)建100w條訂單數(shù)據(jù)
private static List<Order> data() {
List<Order> list = new ArrayList<Order>();
for (int i = 0; i < 300000; i++) {
list.add(new Order());
}
return list;
}
}
所以easyExcel最快,XSSF最慢且占用cpu最高
以上就是Java實(shí)現(xiàn)超大Excel文件解析(XSSF,SXSSF,easyExcel)的詳細(xì)內(nèi)容,更多關(guān)于Java Excel文件解析的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringBoot 集成MQTT實(shí)現(xiàn)消息訂閱的詳細(xì)代碼
本文介紹了如何在SpringBoot中集成MQTT并實(shí)現(xiàn)消息訂閱,主要步驟包括添加依賴、配置文件設(shè)置、啟動(dòng)類(lèi)注解、MQTT配置類(lèi)、消息處理器配置、主題緩存、動(dòng)態(tài)數(shù)據(jù)庫(kù)主題配置以及消息處理服務(wù),感興趣的朋友跟隨小編一起看看吧2024-11-11
Java封裝數(shù)組之動(dòng)態(tài)數(shù)組實(shí)現(xiàn)方法詳解
這篇文章主要介紹了Java封裝數(shù)組之動(dòng)態(tài)數(shù)組實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了java動(dòng)態(tài)數(shù)組的實(shí)現(xiàn)原理、操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2020-03-03
JavaWeb實(shí)戰(zhàn)之用Servlet+JDBC實(shí)現(xiàn)用戶登錄與注冊(cè)
這篇文章主要介紹了JavaWeb實(shí)戰(zhàn)之用Servlet+JDBC實(shí)現(xiàn)用戶登錄與注冊(cè),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很大的幫助,需要的朋友可以參考下2021-04-04
springboot集成schedule實(shí)現(xiàn)定時(shí)任務(wù)
在項(xiàng)目開(kāi)發(fā)過(guò)程中,我們經(jīng)常需要執(zhí)行具有周期性的任務(wù)。通過(guò)定時(shí)任務(wù)可以很好的幫助我們實(shí)現(xiàn)。本篇文章主要介紹了springboot集成schedule實(shí)現(xiàn)定時(shí)任務(wù),感興趣的小伙伴們可以參考一下2018-05-05
SpringBoot使用AOP實(shí)現(xiàn)統(tǒng)計(jì)全局接口訪問(wèn)次數(shù)詳解
這篇文章主要介紹了SpringBoot通過(guò)AOP實(shí)現(xiàn)對(duì)全局接口訪問(wèn)次數(shù)的統(tǒng)計(jì),文章從相關(guān)問(wèn)題展開(kāi)全文內(nèi)容詳情,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-06-06
java方法重寫(xiě)時(shí)需要注意的問(wèn)題
大家好,本篇文章主要講的是java方法重寫(xiě)時(shí)需要注意的問(wèn)題,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Dubbo新版本zk注冊(cè)中心連接問(wèn)題及解決
這篇文章主要介紹了Dubbo新版本zk注冊(cè)中心連接問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05

