我是靠谱客的博主 儒雅白猫,最近开发中收集的这篇文章主要介绍解决海量数据导出Excel慢的问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

此方法为Main方法,逻辑为生成XML转化成XLS,从某种意义上来讲解决了实际问题;

public static void main(String[] args) throws Exception{
StringBuffer sb = new StringBuffer();
try {
OutputStreamWriter write = new OutputStreamWriter(new FileOutputStream(new File("d://aa.xls")),"UTF-8");
BufferedWriter output = new BufferedWriter(write);
sb.append("<?xml version="1.0"?>");
sb.append("n");
sb.append("<?mso-application progid="Excel.Sheet"?>");
sb.append("n");
sb.append("<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet"");
sb.append("n");
sb.append(" xmlns:o="urn:schemas-microsoft-com:office:office"");
sb.append("n");
sb.append(" xmlns:x="urn:schemas-microsoft-com:office:excel"");
sb.append("n");
sb.append(" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"");
sb.append("n");
sb.append(" xmlns:html="http://www.w3.org/TR/REC-html40">");
sb.append("n");
sb.append(" <Styles>n");
sb.append(" <Style ss:ID="Default" ss:Name="Normal">n");
sb.append(" <Alignment ss:Vertical="Center"/>n");
sb.append(" <Borders/>n");
sb.append(" <Font ss:FontName="宋体" x:CharSet="134" ss:Size="12"/>n");
sb.append(" <Interior/>n");
sb.append(" <NumberFormat/>n");
sb.append(" <Protection/>n");
sb.append(" </Style>n");
sb.append(" </Styles>n");
//行数
int rowNum = 20;

int currentRecord = 0;
//总数据量
int total = 2000;
//列数
int columnNum = 10;
//第一个工作表
sb.append("<Worksheet ss:Name="Sheet0">");
sb.append("n");
sb.append("<Table ss:ExpandedColumnCount="" + columnNum
+ "" ss:ExpandedRowCount="" + rowNum
+ "" x:FullColumns="1" x:FullRows="1">");
sb.append("n");
for (int i = 0; i < total; i++) {
if ((currentRecord == rowNum
|| currentRecord > rowNum || currentRecord == 0)
&& i != 0) {// 一个sheet写满
currentRecord = 0;
output.write(sb.toString());
sb.setLength(0);
sb.append("</Table>");
sb.append("<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">");
sb.append("n");
sb.append("<ProtectObjects>False</ProtectObjects>");
sb.append("n");
sb.append("<ProtectScenarios>False</ProtectScenarios>");
sb.append("n");
sb.append("</WorksheetOptions>");
sb.append("n");
sb.append("</Worksheet>");
sb.append("<Worksheet ss:Name="Sheet" + i / rowNum
+ "">");
sb.append("n");
sb.append("<Table ss:ExpandedColumnCount="" + columnNum
+ "" ss:ExpandedRowCount="" + rowNum
+ "" x:FullColumns="1" x:FullRows="1">");
sb.append("n");
}
sb.append("<Row>");
for (int j = 0; j < columnNum; j++) {
sb.append("<Cell><Data ss:Type="String">第"+(i+1)+"列第"+(j+1)+"行</Data></Cell>");
sb.append("n");
}
sb.append("</Row>");
//每三百行数据批量提交一次
if (i % 300 == 0) {
System.out.println("提交了");
output.write(sb.toString());
output.flush();
sb.setLength(0);
}
sb.append("n");
currentRecord++;
}
output.write(sb.toString());
sb.setLength(0);
sb.append("</Table>");
sb.append("<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">");
sb.append("n");
sb.append("<ProtectObjects>False</ProtectObjects>");
sb.append("n");
sb.append("<ProtectScenarios>False</ProtectScenarios>");
sb.append("n");
sb.append("</WorksheetOptions>");
sb.append("n");
sb.append("</Worksheet>");
sb.append("</Workbook>");
sb.append("n");
output.write(sb.toString());
output.flush();
output.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

最后

以上就是儒雅白猫为你收集整理的解决海量数据导出Excel慢的问题的全部内容,希望文章能够帮你解决解决海量数据导出Excel慢的问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部