java千万级数据导出生成文件demo

com.xxx.common.excel.filereader;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.text.NumberFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.Iterator;
import java.util.List;

import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class CreateFileUtil {

public static void main(String[] args) {
    
    //生成100万条数据,耗时非常的短暂

    List<Object[]> rows=new ArrayList<Object[]>();
    Long start=System.currentTimeMillis();
    for(int i=0;i<1000000;i++){
        rows.add(new Object[]{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1});
    }
    Long end=System.currentTimeMillis();

    System.out.println("耗时----- "+(end-start)/1000);

    String filePath="/Users/wangyonglin/Desktop";
    String fileName="test1.txt";


    CreateFileUtil.createTxtFile(rows,filePath,fileName);

    Long kend=System.currentTimeMillis();

    System.out.println("最后结束耗时,插入100万数据,---结束");
    System.out.println((kend-end)/1000);
}

/**
 * 生成.TXT格式文件,行数几乎无上限
 */
public static boolean createTxtFile(List<Object[]> rows, String filePath, String fileName) {
    // 标记文件生成是否成功
    boolean flag = true;

    try {
        // 含文件名的全路径
        String fullPath = filePath + File.separator + fileName + ".txt";

        File file = new File(fullPath);
        if (file.exists()) { // 如果已存在,删除旧文件
            file.delete();
        }
        file = new File(fullPath);
        file.createNewFile();

        // 格式化浮点数据
        NumberFormat formatter = NumberFormat.getNumberInstance();
        formatter.setMaximumFractionDigits(10); // 设置最大小数位为10

        // 格式化日期数据
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");

        // 遍历输出每行
        PrintWriter pfp = new PrintWriter(file, "UTF-8"); //设置输出文件的编码为utf-8
        for (Object[] rowData : rows) {
            StringBuffer thisLine = new StringBuffer("");
            for (int i = 0; i < rowData.length; i++) {
                Object obj = rowData[i]; // 当前字段

                // 格式化数据
                String field = "";
                if (null != obj) {
                    if (obj.getClass() == String.class) { // 如果是字符串
                        field = (String) obj;
                    } else if (obj.getClass() == Double.class || obj.getClass() == Float.class) { // 如果是浮点型
                        field = formatter.format(obj); // 格式化浮点数,使浮点数不以科学计数法输出
                    } else if (obj.getClass() == Integer.class || obj.getClass() == Long.class
                            || obj.getClass() == Short.class || obj.getClass() == Byte.class) { // 如果是整形
                        field += obj;
                    } else if (obj.getClass() == Date.class) { // 如果是日期类型
                        field = sdf.format(obj);
                    }
                } else {
                    field = " "; // null时给一个空格占位
                }

                // 拼接所有字段为一行数据,用tab键分隔
                if (i < rowData.length - 1) { // 不是最后一个元素
                    thisLine.append(field).append("\t");
                } else { // 是最后一个元素
                    thisLine.append(field);
                }
            }
            pfp.print(thisLine.toString() + "\n");
        }
        pfp.close();

    } catch (Exception e) {
        flag = false;
        e.printStackTrace();
    }
    return flag;
}

/**
 * 生成.csv格式文件,行数几乎无上限
 */
public static boolean createCsvFile(List<Object[]> rows, String filePath, String fileName) {
    // 标记文件生成是否成功
    boolean flag = true;

    // 文件输出流
    BufferedWriter fileOutputStream = null;

    try {
        // 含文件名的全路径
        String fullPath = filePath + File.separator + fileName + ".csv";

        File file = new File(fullPath);
        if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
            file.getParentFile().mkdirs();
        }
        if (file.exists()) { // 如果已存在,删除旧文件
            file.delete();
        }
        file = new File(fullPath);
        file.createNewFile();

        // 格式化浮点数据
        NumberFormat formatter = NumberFormat.getNumberInstance();
        formatter.setMaximumFractionDigits(10); // 设置最大小数位为10

        // 格式化日期数据
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");

        // 实例化文件输出流
        fileOutputStream = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file), "GB2312"), 1024);

        // 遍历输出每行
        Iterator<Object[]> ite = rows.iterator();
        while (ite.hasNext()) {
            Object[] rowData = (Object[]) ite.next();
            for (int i = 0; i < rowData.length; i++) {
                Object obj = rowData[i]; // 当前字段
                // 格式化数据
                String field = "";
                if (null != obj) {
                    if (obj.getClass() == String.class) { // 如果是字符串
                        field = (String) obj;
                    } else if (obj.getClass() == Double.class || obj.getClass() == Float.class) { // 如果是浮点型
                        field = formatter.format(obj); // 格式化浮点数,使浮点数不以科学计数法输出
                    } else if (obj.getClass() == Integer.class || obj.getClass() == Long.class
                            || obj.getClass() == Short.class || obj.getClass() == Byte.class) { // 如果是整形
                        field += obj;
                    } else if (obj.getClass() == Date.class) { // 如果是日期类型
                        field = sdf.format(obj);
                    }
                } else {
                    field = " "; // null时给一个空格占位
                }
                // 拼接所有字段为一行数据
                if (i < rowData.length - 1) { // 不是最后一个元素
                    fileOutputStream.write("\"" + field + "\"" + ",");
                } else { // 是最后一个元素
                    fileOutputStream.write("\"" + field + "\"");
                }
            }
            // 创建一个新行
            if (ite.hasNext()) {
                fileOutputStream.newLine();
            }
        }
        fileOutputStream.flush();
    } catch (Exception e) {
        flag = false;
        e.printStackTrace();
    } finally {
        try {
            fileOutputStream.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    return flag;
}

/**
 * 生成.xls格式文件,单页上限: 03版是65536行 ,07版的是1048576行, 10版不知
 */
public static boolean createXlsFile(List<Object[]> rows, String filePath, String fileName) {
    // 标记文件生成是否成功
    boolean flag = true;

    try {
        // 创建一个webbook,对应一个Excel文件
        XSSFWorkbook wb = new XSSFWorkbook();

        // 在webbook中添加一个sheet,对应Excel文件中的sheet
        XSSFSheet sheet = wb.createSheet(fileName);

        // 遍历输出每行
        for (int i = 0; i < rows.size(); i++) {
            Object[] rowData = rows.get(i); // 每一行的数据
            XSSFRow row = sheet.createRow(i);
            for (int j = 0; j < rowData.length; j++) {
                XSSFCell cell = row.createCell(j);
                // 假设只有三种类型的数据
                if (rowData[j].getClass() == String.class) { // String类型数值
                    cell.setCellValue((String) rowData[j]);
                } else if (rowData[j].getClass() == double.class) { // double类型数值
                    cell.setCellValue((Double) rowData[j]);
                } else if (rowData[j].getClass() == int.class) { // int类型数值
                    cell.setCellValue((Integer) rowData[j]);
                }
            }
        }

        String fullPath = filePath + File.separator + fileName + ".xls";// 含文件名的全路径            File file = new File(fullPath);
        File file = new File(fullPath);

        if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
            file.getParentFile().mkdirs();
        }
        if (file.exists()) { // 如果已存在,删除旧文件
            file.delete();
        }
        file.createNewFile();
        FileOutputStream fileOut = new FileOutputStream(file); // 写出数据到文件
        wb.write(fileOut);
        fileOut.close();
    } catch (Exception e) {
        flag = false;
        e.printStackTrace();
    }

    return flag;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值