Java读写csv文件操作
目录
Java读写csv文件操作
内容:
将csv(至少三个字段)里面的数据进行读的操作,将数据读取到pojo类组成的List中,然后按照某种要求进行排序,最后将排序后的结构写入另一个csv文件当中。
具体代码:
csv文件:
需要依赖:
Pojo类
package com.example.demo.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Student {
String name;
String display;
int age;
}
主类:
package com.example.demo.test;
import com.example.demo.pojo.Student;
import java.io.PrintStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.stream.Stream;
import org.jumpmind.symmetric.csv.CsvReader;
import org.jumpmind.symmetric.csv.CsvWriter;
public class Main {
public Main() {
}
public static void main(String[] args) {
ArrayList students = new ArrayList();
try {
CsvReader reader = new CsvReader("自己文件的绝对路径");
//D:\hanzh\easy_test\src\main\java\com\example\demo\test\student.csv
reader.readHeaders();
while(reader.readRecord()) {
String rawRow = reader.getRawRecord();
String[] split = rawRow.split(",");
Student student = new Student();
student.setName(split[0]);
student.setDisplay(split[1]);
student.setAge(Integer.parseInt(split[2]));
students.add(student);
}
} catch (Exception var7) {
var7.printStackTrace();
}
Stream var10000 = students.stream().sorted((a, b) -> {
return b.getAge() - a.getAge();
});
PrintStream var10001 = System.out;
var10000.forEach(var10001::println);
try {
CsvWriter writer = new CsvWriter(Main.class.getResource("").getPath() + "output.csv");
Iterator var9 = students.iterator();
while(var9.hasNext()) {
Student s = (Student)var9.next();
String[] str = new String[]{s.getName(), s.getDisplay(), s.getAge() + ""};
writer.writeRecord(str);
System.out.println(str[0] + " " + str[1] + " " + str[2]);
}
writer.close();
} catch (Exception var6) {
var6.printStackTrace();
}
}
}
最后测试结果: