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();
        }

    }
}

最后测试结果:
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

建桥之魂

建桥人,建桥魂,建桥都是人上人

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值