List中的数据分批写入txt文件中,一个文件只能写入5000条

本文探讨了如何将大量数据从数据库中读取并按5000条数据为单位写入多个文件的方法,同时提出了代码抽象化思路,以便于处理多个列表数据,并自定义文件名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:查询数据库中的数据,封装到List集合中,然后把数据写到文件中,一个文件只能写入5000条,第一个文件命名为01,第二个文件命名为02,以此类推,直到把数据全部写入到文件中。 

package com.sinosoft.light.thth;

import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;

public class TestWriteFile {

    public static void main(String[] args) throws Exception {
        List aNumList = new ArrayList();//这里省略了从数据库中取数的逻辑
        int fileNum = calculationNum(aNumList.size());//根据List集合中的数据计算需要多少个文件
        int baseNum = 5000;//基数,每个文件放5000条数据
        String filePath = "E:/tps/";
        String fileCode = "";
        String fileName = "";
        for (int i = 1; i <= fileNum; i++) {
            if (0 != 1 && 1 < 10) {
                fileCode = "0" + i;
            } else {
                fileCode = "" + i;
            }
            fileName = filePath + "XAJH" + "日期(这里随便写下)" + fileCode + ".txt";
            String writeString = "";//拼装要写入文件的内容
            for (int j = (i - 1) * baseNum + 1; j < i * baseNum; j++) {//这句代码想了一会
                if (j < aNumList.size()) {
                    writeString = writeString + aNumList.get(j);
                } else {
                    break;
                }
            }

            System.out.println("要写入的文件名称为:" + fileName + ",要写入的数据为:" + writeString);
            File fatherFile = new File(filePath);
            if (!fatherFile.exists()) {//没有该文件的时候,创建个文件夹。
                fatherFile.mkdirs();
            }
            File indexFile = new File(fileName);
            PrintWriter indexPrintWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(indexFile), "UTF-8"));
            indexPrintWriter.println(writeString);
            indexPrintWriter.close();
        }

    }

    public static int calculationNum(int ListSize) {
        int baseNum = 5000;//基数,每个文件放5000条数据
        int divisor = ListSize / baseNum; //除数
        int remainder = ListSize % baseNum; //余数
        int fileNum = 0;//最后需要几个文件进行装数据
        if (0 != ListSize) {
            if (0 == divisor) {
                fileNum = 1;
            } else {
                if (0 != remainder) {
                    fileNum = divisor + 1;
                } else {
                    fileNum = divisor;
                }
            }
        } else {
            System.out.println("没有数据,不需要进行运算");
        }
        return fileNum;
    }

}

别讲怎么着,是把问题解决了,但是一审视,我又想到一个问题。

现在只有一个aNumList的数据要封装,假如说我还有bNumList、cNumList等数据都要写入到文件中,而且文件的命名不同,怎么把这一大坨代码给抽象出来,直接输入list和文件命名,就能生成各类的文件呢?


 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值