`
yuelangyc
  • 浏览: 454689 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java大批量导出数据,格式可以为xml或excel.

阅读更多
        最近项目中用到大数据量导出功能.不能确定到底有多大,最少十来万条记录.
        100M的excel文件,excel2003已经不能够打开了,只能用2007版.不知道后期数据量更大的时候怎么办.废话不多说,上代码.Copy别人的.以备以后使用.
       
package com.epay.utils;

/**
 * 大数据量导出成EXCEL或XML
 * @author J.W
 * 2011-06-08
 */
import java.io.BufferedOutputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class Test {
	public static void main(String[] args) {
		StringBuffer sb = new StringBuffer();
		try {
			DataOutputStream rafs = new DataOutputStream(
					new BufferedOutputStream(new FileOutputStream(new File(
							"d://test.xml"))));
			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 sheetcount = 0;
			int recordcount = 20;
			int currentRecord = 0;
			int total = 100;
			int col = 20;
			sb.append("<Worksheet ss:Name=\"Sheet0\">");
			sb.append("\n");
			sb.append("<Table ss:ExpandedColumnCount=\"" + col
					+ "\" ss:ExpandedRowCount=\"" + total
					+ "\" x:FullColumns=\"1\" x:FullRows=\"1\">");
			sb.append("\n");
			for (int i = 0; i < total; i++) {
				if ((currentRecord == recordcount
						|| currentRecord > recordcount || currentRecord == 0)
						&& i != 0) {// 一个sheet写满
					currentRecord = 0;
					rafs.write(sb.toString().getBytes());
					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 / recordcount
							+ "\">");
					sb.append("\n");
					sb.append("<Table ss:ExpandedColumnCount=\"" + col
							+ "\" ss:ExpandedRowCount=\"" + recordcount
							+ "\" x:FullColumns=\"1\" x:FullRows=\"1\">");
					sb.append("\n");
				}
				sb.append("<Row>");
				for (int j = 0; j < col; j++) {
					System.out.println(i);
					sb.append("<Cell><Data ss:Type=\"String\">111</Data></Cell>");
					sb.append("\n");
				}
				sb.append("</Row>");
				if (i % 5000 == 0) {
					rafs.write(sb.toString().getBytes());
					rafs.flush();
					sb.setLength(0);
				}
				sb.append("\n");
				currentRecord++;
			}
			rafs.write(sb.toString().getBytes());
			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");
			rafs.write(sb.toString().getBytes());
			rafs.flush();
			rafs.close();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

       
        文件格式可以自定义,改成XML或者excel都可以, 代码复制到eclipse可以直接运行.还需要再研究研究poi导出.完了以后做个比较,顺便记录下来.
分享到:
评论
1 楼 rbw204 2013-09-03  
单元格内容是中文的时候,打开excel报错,打不开,请问遇到过吗,怎么解决?

相关推荐

    Java大批量导出数据,格式可以为xml或excel..do

    ### Java大批量导出数据至Excel或XML技术详解 #### 技术背景及应用场景 在企业级应用开发中,经常需要处理大量数据的导出需求,例如报表导出、数据分析等场景。对于这类需求,使用Java进行批量数据导出至Excel或...

    java导出大批量(百万以上)数据的excel文件

    - 如上述代码所示,可以导出XML格式的文件,这种文件可以被Excel识别并打开为工作簿。通过分批导出数据到多个XML文件,然后再合并为一个压缩包供用户下载,这种方法适合处理大规模数据。 3. **代码实现细节**: -...

    以读取XML方式的大批量导入Excel

    XML作为一种结构化的数据格式,能够很好地存储和传输大量数据,因此,通过XML来导入Excel是一种有效的解决方案。 首先,我们需要理解XML(eXtensible Markup Language)的基本概念。XML是一种自描述性的标记语言,...

    大批量数据导出到XLS

    本主题聚焦于“大批量数据导出到XLS”,这是一个关于如何高效地将大量数据从网页或其他数据源导出到Excel(XLS)文件的过程。XLS是Microsoft Excel的一种文件格式,广泛用于存储和组织表格数据,便于分析和共享。 ...

    Excel大批量导入导出解决方案.docx

    本文将详细介绍如何避免这些问题,并提供针对不同Excel文件格式(.xls与.xlsx)的大批量数据导入导出的优化方法。 #### 一次线上问题实例 在一次线上问题中,由于执行了一个大数据量的Excel导出操作,导致服务器...

    excel java中导入导出

    博文链接提供的资源“数据大批量导出(有代码有真相).docx”可能包含具体的示例代码和实践案例,可以作为学习和参考的依据。通过深入研究这些示例,开发者能够更好地掌握如何在Java中高效地进行Excel文件的导入导出。

    sql数据导入到access,和xml等文件中

    在IT领域,数据库管理和数据迁移是一项关键任务,尤其是在多种数据格式和系统之间。"SQL数据导入到Access,和XML等文件中"这个主题涉及到的就是如何在不同数据平台间进行数据交换,以实现数据共享和互操作性。让我们...

    报表技术POI&EasyPOI导入导出操作Excel、Word、CSV(讲义、源码、资料).zip

    5. **使用示例**:在Excel的导入导出操作中,EasyPOI可以方便地读取一行数据并映射到Java对象,也可以将Java对象集合一次性写入Excel。对于Word,可以创建模板并替换其中的占位符内容,实现批量生成报告。 6. **...

    H2数据库讲解(教程)

    "**Java大批量导出数据,格式可以为xml或excel..doc**"会指导你如何利用Java编程接口实现数据的XML或Excel格式导入导出,这对于数据迁移或备份很有帮助。 SQL是操作数据库的语言,"**H2Database_SQL语法.doc**"涵盖...

    内存数据库H2

    《Java大批量导出数据,格式可以为xml或excel》可能讲解了如何使用Java编程语言将数据批量导出为XML或Excel格式,这对于数据交换和分析非常有用。H2提供了API来支持这种操作,使得开发者可以方便地与应用程序集成。 ...

    利用POI将word转换成html实现在线阅读

    - **性能优化**:大量Word文档转换可能会消耗大量内存,因此在处理大批量文件时,需要考虑分批处理或使用流式处理。 - **错误处理**:在读取和转换过程中可能出现各种异常,如文件损坏、格式不兼容等,需要编写合适...

    测试培训教材

    项目管理员可以使用QC的Excel插件工具来执行需求的批量导入,进行导入之前请先确认已经访问过MQC主页,并安装了QCMSExcelAddin.exe插件。 插件下载地址: http://updates.merc-int.com/qual ... /msexcel/index.html...

Global site tag (gtag.js) - Google Analytics