在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。
配置文件:
download /download ${fileName}
4、看一下同样的数据内容,csv文件和Excel文件的大小对比:
迷雾城堡免广告 最新版v0.1.30
迷雾城堡免广告是一款非常好玩的模拟建造类手游,玩家无需看广告
鉴车大师免广告 安卓版v1.2.2
鉴车大师免广告是一款非常好玩的模拟类手游,玩家在游戏中不用看
从前有条街 安卓最新版v1.5
从前有条街是一款非常好玩的模拟经营类手游,玩家在游戏中将会进
我的世界源之界冰火魔龙 最新版v阿夜整合
我的世界源之界冰火魔龙模组整合包是一款像素风格的沙河模拟生存
假面骑士创骑腰带模拟器 安卓版v6
假面骑士创骑腰带模拟器是一个专为喜欢假面骑士的用户打造的变身