`
- 浏览:
55654 次
- 性别:
- 来自:
上海
-
在Java Web开发中,经常需要导出大量的数据到Excel,使用POI、JXL直接生成Excel,很容易就造成内存溢出了。
1、有一种方式,就是把数据写成csv格式文件。
1)csv文件可以直接用Excel打开。
2)写csv文件的效率和写txt文件的效率一样高。
3)同样的数据内容,生成的csv文件的大小远远小于生成的Excel文件。
从以上优点就可以看出生成csv文件消耗的内存绝对小于生成Excel文件。
2、按一定的格式去生成csv文件,在Excel中打开的时候就是完整的行和列格式。
例如:在Excel中的格式:
那么,在csv文件中格式就必须为:
就是说,列和列之间,需要用英文输入法状态下的逗号","间隔:风云第一刀,古龙。
3、在Struts2中导出数据到csv文件,并将生成的csv文件路径传递给下载Action进行下载。一个简单的例子。
CsvAction,生成csv文件,并且将生成的csv文件完整路径传递到下载Action。
代码如下 复制代码
package cn.luxh.struts2.action;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import cn.luxh.struts2.entity.Novel;
import com.opensymphony.xwork2.ActionSupport;
/**
* 导出数据到csv文件
* @author Luxh
*/
public class CsvAction extends ActionSupport {
private static final long serialVersionUID = -2862629695443964658L;
/**
* 包含完整路径的文件名
* 传递给下载Action进行下载
*/
private String fileName;
/**
* 导出数据
*/
public String exportData2CSV() {
List<Novel> novels = getNovels();
fileName = "D:/novels.csv";
writeData2CSV(novels,fileName);
return SUCCESS;
}
/**
* 构造一些数据
* 实际上可能是从数据库中把大量的数据查出来
*/
private List<Novel> getNovels() {
List<Novel> novels = new ArrayList<Novel>();
Novel novel1 = new Novel("风云第一刀","古龙",new Date());
Novel novel2 = new Novel("书剑恩仇录","金庸",new Date());
Novel novel3 = new Novel("陆小凤传奇","古龙",new Date());
Novel novel4 = new Novel("鹿鼎记","金庸",new Date());
novels.add(novel1);
novels.add(novel2);
novels.add(novel3);
novels.add(novel4);
return novels;
}
/**
* 把数据按一定的格式写到csv文件中
* @param novels 数据集合
* @param fileName csv文件完整路径
*/
public void writeData2CSV(List<Novel> novels,String fileName) {
FileWriter fw = null;
try {
fw = new FileWriter(fileName);
//输出标题头
//注意列之间用","间隔,写完一行需要回车换行"rn"
String title = "序号,小说名称,作者,出版日期rn";
fw.write(title);
String content = null;
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
for(int i=0;i<novels.size();i++) {
Novel novel = novels.get(i);
//注意列之间用","间隔,写完一行需要回车换行"rn"
content =(i+1)+","+novel.getName()+","+novel.getAuthor()+","+sdf.format(novel.getPublishDate())+"rn";
fw.write(content);
}
}catch(Exception e) {
e.printStackTrace();
throw new RuntimeException(e);
}finally {
try {
if(fw!=null) {
fw.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
配置文件:
代码如下 复制代码
<!--将csv文件路径传递到公共的下载Action进行下载 -->
<action name="exportData2CSV" class="cn.luxh.struts2.action.CsvAction" method="exportData2CSV">
<result type="redirectAction">
<param name="actionName">download</param>
<param name="nameSpace">/download</param>
<!--附件的完整路径 ,传递给下载Action -->
<param name="fileName">${fileName}</param>
</result>
</action>
4、看一下同样的数据内容,csv文件和Excel文件的大小对比:
更多详细内容请查看:http://www.111cn.net/jsp/Java/43114.htm
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
### Java POI 大量数据导出到Excel详解 #### 一、背景介绍 在日常工作中,经常需要处理大量的数据并将其导出为Excel文件,特别是在金融、电商等行业。Java POI库作为一款强大的用于读写Microsoft Office文档的Java ...
在Java开发中,将数据导出到Excel是一种常见的需求,特别是在数据分析、报表生成或数据交换等场景下。Excel因其易用性和丰富的格式设置能力,成为处理结构化数据的理想选择。本篇文章将深入探讨如何利用Java实现这一...
在Java编程中,导出数据到Excel是一种常见的需求,特别是在数据分析、报表生成或者数据交换的场景下。Apache POI是一个强大的库,专为处理Microsoft Office格式的文件,尤其是Excel(.xlsx和.xls)文件。本篇文章将...
在Java开发中,将数据导出到Excel是一种常见的需求,特别是在数据分析、报表生成或数据交换等场景。Excel作为Microsoft Office套件的一部分,以其强大的表格处理功能和良好的兼容性深受用户喜爱。下面,我们将深入...
在Java编程中,导出数据到Excel是一种常见的需求,尤其当需要将图片与文本一起展示在电子表格中时。这个任务通常涉及到使用第三方库来处理Excel文件,因为Java标准库并未提供直接支持图像到Excel的功能。以下是一些...
这是因为Excel文件格式本身的设计,以及Java默认处理大数据的方式,可能导致内存占用过高,尤其是在一次性加载大量数据到内存中进行处理时。为了解决这个问题,我们可以采用以下几种策略: 1. **分批导出**: - ...
在IT行业中,将数据库数据导出到Excel文件是一种常见的需求,尤其在数据分析、报表生成或者数据备份时。本文将详细讲解如何使用Java实现从MySQL数据库的表导出到Excel文件的过程,以及涉及到的关键技术和工具。 ...
在Java开发中,处理大数据量的Excel导出是一项常见的任务,尤其当数据量达到数十万条时,单个Excel文件可能会遇到性能瓶颈或格式限制...这种方案在实际项目中具有很高的实用价值,尤其对于需要大量数据导出的业务场景。
在Java编程中,导出数据到Excel是一种常见的需求,特别是在数据分析、报表生成或者数据交换的场景下。Excel作为Microsoft Office套件的一部分,以其强大的表格处理功能和良好的兼容性深受开发者喜爱。本文将深入探讨...
Java多线程导出Excel是处理大数据量时的一种高效策略,尤其在面对千万级别的数据时。传统的Apache POI库在处理大规模数据时可能会遇到栈溢出(StackOverflowError)和内存溢出(OutOfMemoryError)等问题,因为这些...
在IT行业中,Excel作为一种强大的电子表格工具,常用于数据分析、报告制作和数据交换。"Excel导出数据(根据Excel模板定义)"这个主题涉及到的核心技术是如何根据预设的Excel模板生成和导出数据,通常用于批量生成报表...
在Java编程环境中,导出数据到PDF、Excel和Word格式是一项常见的需求,这通常涉及到文件处理和格式转换。以下是对这个主题的详细说明: 一、PDF(Portable Document Format)文件导出 PDF是一种通用的文件格式,...
在Java编程环境中,将Oracle数据库的表结构导出到Excel是一种常见的需求,特别是在数据库管理和数据分析时。这个场景可以通过两个核心类来实现:`TableStructureToExcel.java`和`ConnectionOracle.java`。这两个类...
SQL Server提供了多种方式来导出数据,其中一种常见的方法是通过`OPENROWSET`函数和`BCP`命令行工具。此外,还可以编写存储过程并结合Windows计划任务或SQL Server Agent作业实现定时任务的功能。 ### 一、基本原理...
Java导出数据到Excel是一种常见的需求,特别是在Web应用或者数据处理场景中。这段代码展示了如何使用JExcelAPI库来实现这个功能。JExcelAPI是一个Java库,它允许开发者读写Microsoft Excel格式的文件,而无需依赖于...
在Java编程环境中,将JSP表格中的数据导出到Excel文件是一种常见的需求,尤其是在数据分析、报表生成和数据交换等场景中。本篇文章将详细介绍如何利用Java实现这一功能,主要涉及的技术包括Java Servlet、JSP以及...
这篇博客“导出数据库数据到Excel”提供了一种实现这一目标的方法,通过源代码的形式,帮助开发者实现这一功能。 首先,我们需要理解数据库与Excel之间的数据交换。数据库,如MySQL、Oracle或SQL Server,存储结构...
这个Java demo提供了一种实用的方法来处理Excel大数据量导出的问题,它适用于那些需要高效、稳定地处理大量数据并生成Excel报告的业务场景。通过深入理解并实践这个示例,开发者可以更好地掌握Apache POI的流式API,...