`

Java采用反射导出CSV文件替代导出Excel

阅读更多
package com.resoft.prophet.util;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletResponse;

import org.apache.commons.beanutils.BeanUtils;

/**
 * @作者: liwenjie
 * @日期: 2010-03-27
 * @描述: CSV导出工具
 */
public class CSVUtils {

	/**
	 * 导出为CVS文件
	 * 
	 * @param exportData
	 */
	public static File createCSVFile(List exportData, LinkedHashMap rowMapper, String outPutPath) {
		File csvFile = null;
		BufferedWriter csvFileOutputStream = null;
		try {
			csvFile = File.createTempFile("temp", ".csv", new File(outPutPath));
			// GB2312使正确读取分隔符","
			csvFileOutputStream = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(csvFile), "GB2312"),
					1024);
			// 写入文件头部
			for (Iterator propertyIterator = rowMapper.entrySet().iterator(); propertyIterator.hasNext();) {
				java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator.next();
				csvFileOutputStream.write("\"" + propertyEntry.getValue().toString() + "\"");
				if (propertyIterator.hasNext()) {
					csvFileOutputStream.write(",");
				}
			}
			csvFileOutputStream.newLine();
			// 写入文件内容
			for (Iterator iterator = exportData.iterator(); iterator.hasNext();) {
				Object row = (Object) iterator.next();
				for (Iterator propertyIterator = rowMapper.entrySet().iterator(); propertyIterator.hasNext();) {
					java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator.next();
					csvFileOutputStream.write("\""
							+ BeanUtils.getProperty(row, propertyEntry.getKey().toString()).toString() + "\"");
					if (propertyIterator.hasNext()) {
						csvFileOutputStream.write(",");
					}
				}
				if (iterator.hasNext()) {
					csvFileOutputStream.newLine();
				}
			}
			csvFileOutputStream.flush();
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			try {
				csvFileOutputStream.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
		return csvFile;
	}

	/**
	 * 导出为CSV文件
	 * 
	 * @param response
	 * @param exportData
	 * @param propertyNames
	 * @param fileName
	 * @param outputPath
	 * @throws FileNotFoundException
	 */
	public static void exportToCSVFile(HttpServletResponse response, List exportData, LinkedHashMap rowMapper,
			String fileName, String outputPath) throws FileNotFoundException {
		File csvFile = createCSVFile(exportData, rowMapper, outputPath);
		FileUtils.downFile(response, fileName, new FileInputStream(csvFile));
		csvFile.delete();
	}

	public static void main(String[] args) {
		List exportData = new ArrayList<Map>();
		Map row1 = new LinkedHashMap<String, String>();
		row1.put("1", "11");
		row1.put("2", "12");
		row1.put("3", "13");
		row1.put("4", "14");
		exportData.add(row1);
		row1 = new LinkedHashMap<String, String>();
		row1.put("1", "21");
		row1.put("2", "22");
		row1.put("3", "23");
		row1.put("4", "24");
		exportData.add(row1);
		List propertyNames = new ArrayList();
		LinkedHashMap map = new LinkedHashMap();
		map.put("1", "第一列");
		map.put("2", "第二列");
		map.put("3", "第三列");
		map.put("4", "第四列");
		CSVUtils.createCSVFile(exportData, map, "c:/");
	}
}

   上述为导出为csv的代码,rowmapper存储列头以及数据的属性字符串,通过反射,得到bean中的属性值,此hashmap为linkedhashmap,确保列头有序,该代码可以从IBatis中得到List<Map>,List<实体类>,然后统一导出。

 

   注意:需要注意的是写入文件时指定的是GB2312的编码,如果指定为UTF-8的编码,采用Excel打开为乱码,如果不写编码,默认为操作系统的编码,导出后采用Editplus打开为GB3212编码,考虑到服务器的默认编码可能不是客户端的中文操作系统的GB2312的编码,因此我们显示指定编码为GB2312。如果设置为UTF-8编码,Excel之所以为乱码,应该是Office程序按照操作系统的编码读取文件。

          如果采用UNICODE编码,逗号可能无法正确解析,数据将合并为一列

 

   对于ANSI编码用Excel可以正确打开无乱码,如果是中文windows平台,据说会转译为GB312,如果是日文的操作系统,转译为日文编码。

 

   对于ANSI编码和GB2312编码的区别,需要再研究。

 

   最近一直探索大数据量导出Excel的方案,采用导出为csv是一种比较变通的方式。

 

0
1
分享到:
评论
2 楼 liwenjie 2010-06-24  
这是我们项目自己的代码,呵呵 不过可以使用struts2的下载文件功能 配置一个streamresult,网上很多,可以参考
1 楼 luodayong 2010-06-23  
看到楼主文章,非常需要,真感谢!然后有个小问题想请问:您的代码第90行里面有个downFile方法,是从哪里来的呢?我引入common-io.jar包,可以没有这个方法,请楼主指点,谢谢!

相关推荐

    Java导出CSV文件

    java导出数据时,如果对数据格式没有特殊要求,为了提高效率可以导出CSV格式的文件,导出CSV文件不支持多个sheet页。

    java 浏览器导出csv文件

    1.浏览器点击导出按钮,直接下载到本地,服务器不生成临时文件; 2.生成csv,中文无乱码,数据不会科学计数法; 3.支持大数据下载; 4.后台服务java语言实现,前端不限制; 5.前端代码: [removed]void(0)" class=...

    java导出csv文件并压缩(含下载提示功能)

    在Java编程环境中,导出CSV(逗号分隔值)文件并将其压缩成ZIP格式是一项常见的任务,特别是在处理大量数据时。CSV文件因其简洁、通用的格式,常用于数据交换和存储。本教程将深入讲解如何实现这个过程,并提供前...

    java导出CSV文件,EXCEL文件(不用指定下载路劲)

    在Java编程中,导出CSV(Comma Separated Values)和Excel文件是常见的数据处理任务,特别是在数据分析、报表生成和数据交换场景下。本篇将详细介绍如何在Java中实现这两个功能,无需指定下载路径,直接将文件保存到...

    java使用jdbc将数据库数据导出到csv文件.pdf

    Java 使用 JDBC 将数据库数据导出到 CSV 文件 Java 是一种广泛使用的编程语言,它提供了多种方式来处理数据库数据,而 JDBC(Java Database Connectivity)是 Java 中连接数据库的标准 API 之一。将数据库数据导出...

    java 大数据导出csv小工具

    1. `ExportCsvUtil.class`:这是工具的核心类,可能包含了实现数据导出到CSV的具体逻辑。 2. `CsvDto.class`:Dto(Data Transfer Object)通常用于数据传输,这里的CsvDto可能是用于封装数据的对象,便于转换为CSV...

    java实现导出csv文件并上传sftp

    综上所述,通过使用univocity-parsers库,我们可以在Java后端将数据导出为CSV文件,然后利用JSch库将生成的CSV文件安全地上传到SFTP服务器。这个过程涉及到了文件操作、网络传输和安全性等多个方面的知识,对于开发...

    java 导出csv文件并上传sftp

    结合以上两个部分,你就可以在Java程序中实现从数据导出到CSV文件,再到SFTP服务器的完整流程。univocity-parsers和JSCH是强大的工具,能够帮助你高效、安全地处理数据传输任务。在实际项目中,你可能还需要考虑错误...

    java 导出csv格式文件(支持实体类输入)

    java 导出csv格式文件(支持实体类输入)

    java实现csv导出千万级数据实例

    本实例聚焦于“java实现csv导出千万级数据实例”,旨在提供一个高效、稳定的解决方案,避免因数据量过大而导致的性能问题,如Java中的栈溢出(Stack Overflow)。CSV(Comma Separated Values)格式因其简单、通用性...

    1-Gbase导出csv文件教程

    1-Gbase导出csv文件教程

    java 根据javaBean反射自定义导出 excel、xml、pdf、csv

    在Java编程中,根据JavaBean反射来实现数据的导出,如...总之,JavaBean结合反射机制可以灵活地处理数据,而通过各种库支持,我们可以方便地将数据导出到Excel、XML、PDF和CSV等多种格式,满足不同的数据交换需求。

    java csv大数据量导出(千万级别,不会内存溢出)

    在Java开发中,处理大数据量的数据导出是一个常见的挑战,特别是在CSV格式的文件处理上。CSV(Comma Separated Values)是一种广泛使用的数据交换格式,因其简单性和通用性而受到青睐。然而,当数据量达到千万级别时...

    thinkphp下 导入导出csv文件

    标题"thinkphp下导入导出csv文件"涉及到的主要知识点包括: 1. CSV文件格式:CSV文件是以逗号分隔的纯文本文件,每个记录占据一行,每个字段之间由逗号分隔。这种格式使得数据可以轻松地在各种应用程序之间传递,如...

    java导出,导入CSV

    例如,`exportToCSV()`用于导出数据到CSV文件,而`importFromCSV()`则用于从CSV文件导入数据。这些方法可能会处理异常,确保文件操作的正确性,并可能包含一些额外的逻辑,比如处理空值、特殊字符等。 在实际应用中...

    asp.net导出csv文件

    ASP.NET 导出 CSV 文件是指使用 ASP.NET 框架将数据导出到 CSV 文件格式中。CSV(Comma Separated Values)是一种常用的文本文件格式,用于存储表格数据。ASP.NET 提供了多种方式来导出 CSV 文件,本文将介绍其中的...

    csv.js导出csv格式文件

    本篇文章将深入探讨如何使用`csv.js`来导出CSV格式的文件。 首先,`csv.js`库主要包含两个核心部分:`parse`和`stringify`。`parse`用于解析CSV字符串成JavaScript对象数组,而`stringify`则将JavaScript对象数组...

    fastadmin 导出csv文件

    fastadmin 导出csv文件

    Asp.net 导出Excel文件总结(导出csv、Office COM组建、Jet OLEDB、NPOI)

    在Asp.net开发中,有时候我们需要将数据导出到Excel文件以便用户下载或者进行进一步的数据处理。本篇文章将总结四种常见的导出Excel的方法:导出CSV文件、使用Office COM组件、利用Jet OLEDB以及使用NPOI库。 1. **...

    csv文件导入导出工具类

    csv的文件的导入导出可能会用的到,需要的可以下一下把

Global site tag (gtag.js) - Google Analytics