java实现写大量数据到文件中

  • 生成.txt文件
  • 生成.csv文件
  • 生成.xls文件
  • 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.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 {
    
        /**
         * 生成.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("	");
                        } else { // 是最后一个元素
                            thisLine.append(field);
                        }
                    }
                    pfp.print(thisLine.toString() + "
    ");
                }
                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);
                if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录
                    file.getParentFile().mkdirs();
                }
                if (file.exists()) { // 如果已存在,删除旧文件
                    file.delete();
                }
                file = new File(fullPath);
                file.createNewFile();
                FileOutputStream fileOut = new FileOutputStream(file); // 写出数据到文件
                wb.write(fileOut);
                fileOut.close();
            } catch (Exception e) {
                flag = false;
                e.printStackTrace();
            }
    
            return flag;
        }
    
    }

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值