package club.utils;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.RandomAccessFile;
import java.util.List;
import club.model.Student;
public class ImportInfoFromText {
public static final String OPEN_FILE_STYLE="r"; //r=read
public static final String FIELLD_LIMIT_CHAR="\\|";//这里竖线需要被转义一下
public static void main(String[] args) {//执行测试
// String filePath="/home/left/Downloads/test.txt";
String filePath="D:\\test.txt";
readFromText(filePath);
}
/**
* 从文本中读取信息
* @param filePath
*/
public static int readFromText(String filePath) {
String line_record=null;
int count=0;
try {
RandomAccessFile raf=new RandomAccessFile(filePath, OPEN_FILE_STYLE);
while(null!=(line_record=raf.readLine())) {
//这里看操作系统的编码集,一般Windows中文默认是GBK,Linux是UTF-8
line_record=new String(line_record.getBytes("ISO-8859-1"),"GBK");
Student stu = parseRecord(line_record);
System.out.println(stu);
count+=1;
}
System.out.println("本次共导入数据 "+count+" 条");
} catch (FileNotFoundException ef) {
ef.printStackTrace();
} catch (IOException ei) {
ei.printStackTrace();
}
return count;
}
/**
*
* @param line_record
* @return
*/
public static Student parseRecord(String line_record){
Student stu=new Student();
String[] fields=line_record.split(FIELLD_LIMIT_CHAR);//拆分块记录
stu.setId(fields[0]);
stu.setName(fields[1]);
stu.setGender(fields[2]);
stu.setAge(Integer.parseInt(fields[3]));
stu.setScore(Double.parseDouble(fields[4]));
return stu;
}
public void writeToTxt(String path,String fileName) throws IOException {
Student stu=new Student();
stu.setFile_status("01");//对于文件状态,01表示未导出,02表示导出中,03表示已导出成功.
List stus=null;//通过查询得到
int count=0;
OutputStreamWriter out=new OutputStreamWriter(new FileOutputStream(path+fileName,true), "UTF-8");
try {
if(stus.size()>0) {
for (Student student : stus) {
stu.setId(student.getId());
stu.setFile_status("02");
if(1==2) {//如果更新操作顺利执行
out.write(student.toString());//具体格式参照toString
stu.setFile_status("03");
if(true) {
count+=1;
}
}else {
System.out.println("更新当前条数失败 ID为 "+student.getId());
}
}
System.out.println("本次共成功导出文到文件 "+count+" 条");
}else {
System.out.println("未能查询到需要导出的数据");
}
} catch (Exception e) {
System.out.println("writeToTxt error");
}finally {
out.flush();
out.close();
}
}
}