JAVA - 将数据生成为TXT文件

目录

前言

一、文件写入的笔 —— PrintWriter

二、实现步骤

1.文件判断

2.读取数据

总结


前言

开发过程中需要将千万级数据导出为文件,因excel对行数有限制,最终决定将文件定为TXT文件,TXT文件对行数近乎无限制。


一、文件写入的笔 —— PrintWriter

进行文件写入使用的是PrintWriter,具有自动行刷新的缓冲字符输出流,特点是可以按行写出字符串,并且可以自动行刷新。最开始使用的是指定文件和字符集的构造方法,但是测试时发现该构造方法每次打开文件时会清空现有数据,重新写入,无法以追加的方式写入文件,但是因为是千万级数据量的写入,必定是分次写入,最后改为指定输出流的方式,在输出流中指定文件写入方式为追加。

二、实现步骤

实现方法也不难,首先对JSONArray数组进行遍历,获取JSONObject对象,再对JSONObject进行遍历,存在键时,将其对应的值取出,进行格式化处理后,写入文件中。

1.文件判断

判断文件是否存在,不存在则创建:

File file = new File(fullPath);
File folder = new File(path);
if (!folder.exists() && !folder.isDirectory()) {
    // 如果不存在,创建文件夹
    folder.mkdirs();
}
if (!file.exists()) {
    file.createNewFile();
}

2.读取数据

遍历JSONArray数组,获取JSONObject对象,再对JSONObject进行遍历,存在键时,将其对应的值取出,进行格式化处理后写入文件:

for (int i = 0; i < jsonArray.size(); i++) {
                JSONObject jsonObject = jsonArray.getJSONObject(i);
                if (jsonObject.isEmpty()) {
                    break;
                }
                StringBuilder thisLine = new StringBuilder("");
                for (Iterator<String> iterator = jsonObject.keySet().iterator(); iterator.hasNext(); ) {
		// 遍历每个字段,并进行格式化处理
	}
}

总结

文件写入总体来说还是很简单的,就是读取数据写入文件中,需要注意文件写入的方式、数据字段的格式化、何时进行文件写入、最后一定记得关闭流。

为方便大家使用,现将完整代码给出:

public boolean createTxtFile(JSONArray jsonArray, String path, String filename) {
        // 标记文件生成是否成功
        boolean flag = true;
        try {
            // 含文件名的全路径
            String[] strings = {path, filename, ".txt"};
            String fullPath = StrUtils.strSplice(strings);
            File file = new File(fullPath);
            File folder = new File(path);
            if (!folder.exists() && !folder.isDirectory()) {
                // 如果不存在,创建文件夹
                folder.mkdirs();
            }
            if (!file.exists()) {
                file.createNewFile();
            }
            // 格式化浮点数据
            NumberFormat formatter = NumberFormat.getNumberInstance();
            // 设置最大小数位为10
            formatter.setMaximumFractionDigits(10);
            // 格式化日期数据
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
            // 遍历输出每行
            PrintWriter pfp = new PrintWriter(new FileOutputStream(file, true));
            for (int i = 0; i < jsonArray.size(); i++) {
                JSONObject jsonObject = jsonArray.getJSONObject(i);
                if (jsonObject.isEmpty()) {
                    break;
                }
                StringBuilder thisLine = new StringBuilder("");
                for (Iterator<String> iterator = jsonObject.keySet().iterator(); iterator.hasNext(); ) {
                    // 当前字段
                    String key = iterator.next();
                    Object obj = jsonObject.get(key);
                    // 格式化数据
                    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 {
                        // null时给一个空格占位
                        field = " ";
                    }
                    // 拼接所有字段为一行数据,用tab键分隔
                    // 不是最后一个元素
                    if (iterator.hasNext()) {
                        thisLine.append(field).append("\t");
                    } else {
                        // 是最后一个元素
                        thisLine.append(field);
                    }
                }
                pfp.print(thisLine.toString() + "\n");
            }
            pfp.close();
        } catch (Exception e) {
            flag = false;
            logger.error("生成txt文件失败", e);
        }
        return flag;
    }

  • 9
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
生成对应数据的工具通常被称为 Excel 操作库或 Excel 处理库,可以通过编程语言(如 Python、Java、C# 等)调用,实现在 Excel 模板中填充对应的数据。 以下以 Python 中的 openpyxl 库为例,介绍如何利用 Excel 模板生成对应数据。 1. 安装 openpyxl 库 ```bash pip install openpyxl ``` 2. 准备 Excel 模板 在 Excel 中创建一个模板,将需要填充数据的区域留空,然后保存为 *.xlsx 格式的文件,如下图所示: ![Excel模板示例](https://img-blog.csdnimg.cn/20211008213447119.png) 3. 编写代码 ```python from openpyxl import load_workbook # 打开 Excel 文件 wb = load_workbook("template.xlsx") # 选择需要填充数据的工作表 ws = wb.active # 填充数据 ws["B2"] = "张三" ws["B3"] = "男" ws["B4"] = "25" ws["B5"] = "北京市海淀区" # 保存文件 wb.save("output.xlsx") ``` 在上面的代码中,我们首先通过 `load_workbook` 函数打开 Excel 文件,然后选择需要填充数据的工作表,使用类似于访问字典的方式填充数据,最后保存文件即可。 4. 运行程序 将上面的代码保存为 `generate_data.py`,然后在命令行中执行如下命令: ```bash python generate_data.py ``` 程序会自动打开 Excel 模板,填充数据,然后保存为 `output.xlsx` 文件。 以上就是利用 Excel 模板生成对应数据的基本步骤。需要注意的是,在使用 Excel 操作库时,需要根据具体的库和语言选择对应的 API 进行操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值