问题:查询数据库中的数据,封装到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和文件命名,就能生成各类的文件呢?