java 读取csv到list,再将list集合数据写入新的csv文件中

简介: java 读取csv到list,再将list集合数据写入新的csv文件中

一、java读写csv文件

1、说在前面

本文主要是借助 opencsv-5.4.jar工具包,来实现java对csv文件的读取,并将读取的结果,存放到一个list集合中,然后再写入到一个新的csv文件中。

2、准备工作

(1)opencsv-5.4.jar工具jar包,可以下载
(2)实体类 Domain,该类的核心之处就是要加toString()方法,因为后面解析的时候需要用到
package zgw.pojo;
public class Domain {
    public String scqy;
    public String cpdl;
    public String cpxl;
    public String cpph;
    public String xqjhsl;
    public String qdck;
    public String dccf;
    public String ckmax;
    public String jhsj;
    public String drpcbh;
    public String ckl;
    public String rkl;
    public String qckc;
    public String ztkc;
    public String kskcl;
    public String yswf;
    public String rksj;
    public String cksj;
    public String ztcpyqddq;
    public String kccz;
    public String getKccz() {
        return kccz;
    }
    public void setKccz(String kccz) {
        this.kccz = kccz;
    }
    public String getScqy() {
        return scqy;
    }
    public void setScqy(String scqy) {
        this.scqy = scqy;
    }
    public String getCpdl() {
        return cpdl;
    }
    public void setCpdl(String cpdl) {
        this.cpdl = cpdl;
    }
    public String getCpxl() {
        return cpxl;
    }
    public void setCpxl(String cpxl) {
        this.cpxl = cpxl;
    }
    public String getCpph() {
        return cpph;
    }
    public void setCpph(String cpph) {
        this.cpph = cpph;
    }
    public String getXqjhsl() {
        return xqjhsl;
    }
    public void setXqjhsl(String xqjhsl) {
        this.xqjhsl = xqjhsl;
    }
    public String getQdck() {
        return qdck;
    }
    public void setQdck(String qdck) {
        this.qdck = qdck;
    }
    public String getDccf() {
        return dccf;
    }
    public void setDccf(String dccf) {
        this.dccf = dccf;
    }
    public String getCkmax() {
        return ckmax;
    }
    public void setCkmax(String ckmax) {
        this.ckmax = ckmax;
    }
    public String getJhsj() {
        return jhsj;
    }
    public void setJhsj(String jhsj) {
        this.jhsj = jhsj;
    }
    public String getDrpcbh() {
        return drpcbh;
    }
    public void setDrpcbh(String drpcbh) {
        this.drpcbh = drpcbh;
    }
    public String getCkl() {
        return ckl;
    }
    public void setCkl(String ckl) {
        this.ckl = ckl;
    }
    public String getRkl() {
        return rkl;
    }
    public void setRkl(String rkl) {
        this.rkl = rkl;
    }
    public String getQckc() {
        return qckc;
    }
    public void setQckc(String qckc) {
        this.qckc = qckc;
    }
    public String getZtkc() {
        return ztkc;
    }
    public void setZtkc(String ztkc) {
        this.ztkc = ztkc;
    }
    public String getKskcl() {
        return kskcl;
    }
    public void setKskcl(String kskcl) {
        this.kskcl = kskcl;
    }
    public String getYswf() {
        return yswf;
    }
    public void setYswf(String yswf) {
        this.yswf = yswf;
    }
    public String getRksj() {
        return rksj;
    }
    public void setRksj(String rksj) {
        this.rksj = rksj;
    }
    public String getCksj() {
        return cksj;
    }
    public void setCksj(String cksj) {
        this.cksj = cksj;
    }
    public String getZtcpyqddq() {
        return ztcpyqddq;
    }
    public void setZtcpyqddq(String ztcpyqddq) {
        this.ztcpyqddq = ztcpyqddq;
    }
    public Domain() {
    }
    public Domain(String scqy, String cpdl, String cpxl, String cpph, String xqjhsl, String qdck, String dccf, String ckmax, String jhsj, String drpcbh, String ckl, String rkl, String qckc, String ztkc, String kskcl, String yswf, String rksj, String cksj, String ztcpyqddq,String kccz) {
        this.scqy = scqy;
        this.cpdl = cpdl;
        this.cpxl = cpxl;
        this.cpph = cpph;
        this.xqjhsl = xqjhsl;
        this.qdck = qdck;
        this.dccf = dccf;
        this.ckmax = ckmax;
        this.jhsj = jhsj;
        this.drpcbh = drpcbh;
        this.ckl = ckl;
        this.rkl = rkl;
        this.qckc = qckc;
        this.ztkc = ztkc;
        this.kskcl = kskcl;
        this.yswf = yswf;
        this.rksj = rksj;
        this.cksj = cksj;
        this.ztcpyqddq = ztcpyqddq;
        this.kccz = kccz;
    }
    @Override
    public String toString() {
        return "Domain{" +
                "scqy='" + scqy + '\'' +
                ", cpdl='" + cpdl + '\'' +
                ", cpxl='" + cpxl + '\'' +
                ", cpph='" + cpph + '\'' +
                ", xqjhsl='" + xqjhsl + '\'' +
                ", qdck='" + qdck + '\'' +
                ", dccf='" + dccf + '\'' +
                ", ckmax='" + ckmax + '\'' +
                ", jhsj='" + jhsj + '\'' +
                ", drpcbh='" + drpcbh + '\'' +
                ", ckl='" + ckl + '\'' +
                ", rkl='" + rkl + '\'' +
                ", qckc='" + qckc + '\'' +
                ", ztkc='" + ztkc + '\'' +
                ", kskcl='" + kskcl + '\'' +
                ", yswf='" + yswf + '\'' +
                ", rksj='" + rksj + '\'' +
                ", cksj='" + cksj + '\'' +
                ", ztcpyqddq='" + ztcpyqddq + '\'' +
                ", kccz='" + kccz + '\'' +
                '}';
    }
}

3、java读取csv文件

package zgw.com;
//统计
import com.opencsv.CSVWriter;
import zgw.pojo.Domain;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class CSV {
    public static void main(String[] args) {
        //读取csv的数据
        ArrayList<Domain> domains = readCSV();
        System.out.println(domains);
    }
    private static ArrayList<Domain> readCSV() {
        ArrayList<Domain> list=new ArrayList<>();
        InputStreamReader inputStreamReader;
        try {
            inputStreamReader = new InputStreamReader(new FileInputStream("C:\\Users\\wyq\\Desktop\\test1.csv"));
            Scanner inputStream = new Scanner(inputStreamReader);
            inputStream.nextLine(); // 第一行表头不要
            while (inputStream.hasNext()) {
                String data = inputStream.nextLine().replace(" ",""); // 得到一行数据
                String[] line = data.split(","); // 分割数据
                if (line.length>0){
                    Domain domain=new  Domain();
                    domain.setScqy(line[0]);
                    domain.setCpdl(line[1]);
                    domain.setCpxl(line[2]);
                    domain.setCpph(line[3]);
                    domain.setXqjhsl(line[4]);
                    domain.setQdck(line[5]);
                    domain.setDccf(line[6]);
                    domain.setCkmax(line[7]);
                    domain.setJhsj(line[8]);
                    domain.setDrpcbh(line[9]);
                    domain.setCkl(line[10]);
                    domain.setRkl(line[11]);
                    domain.setQckc(line[12]);
                    domain.setZtkc(line[13]);
                    domain.setKskcl(line[14]);
                    domain.setYswf(line[15]);
                    domain.setRksj(line[16]);
                    domain.setCksj(line[17]);
                    if (line.length > 18) {
                        domain.setZtcpyqddq(line[18]);
                    }
                    list.add(domain);
                }
            }
            inputStream.close();
            System.out.println("数据读取成功");
            return list;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}

4、java将list集合数据写入csv文件

package zgw.com;
//统计
import com.opencsv.CSVWriter;
import zgw.pojo.Domain;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class CSV {
    public static void main(String[] args) {
        //读取csv的数据
        ArrayList<Domain> domains = readCSV();
        System.out.println(domains);
        //写入csv数据
        writeCSV(domains);
    }
    private static void writeCSV(ArrayList<Domain> list) {
        //设置路径及文件名称
        String fileName = "C:\\Users\\wyq\\Desktop\\test1.csv";
        CSVWriter writer = null;
        //装业务数据集合
        List<String[]> data = new ArrayList<>();
        String[] header={"生产企业","产品大类","产品小类","产品牌号","需求计划数量","起点仓库","吨仓储费(元/吨)","仓库容量最大值","计划时间","导入批次编号","出库量","入库量","期初库存","在途库存","可售库存量","已售未发","入库时间","出库时间","在途产品预计到达期"};
        data.add(header);
        try {
            for (Domain domain : list) {
                String[] string = domain.toString().replace("'","").replace("}","").split(",");
                String[] string1 =new String[19];
                for (int i = 0; i < string.length; i++) {
                    if (string[i]!=null){
                        if (string[i].split("=")[1].equals("null")){
                            string1[i]="";
                        }else {
                            string1[i]=string[i].split("=")[1];
                        }
                    }else{
                        string1[i]="";
                    }
                }
                data.add(string1);
            }
            // 创建文件所在目录
            FileOutputStream fileOutputStream = new FileOutputStream(fileName);
            fileOutputStream.write(0xef); //加上这句话
            fileOutputStream.write(0xbb); //加上这句话
            fileOutputStream.write(0xbf); //加上这句话
            writer = new CSVWriter(new OutputStreamWriter(fileOutputStream, StandardCharsets.UTF_8.name()), CSVWriter.DEFAULT_SEPARATOR, CSVWriter.NO_QUOTE_CHARACTER, CSVWriter.DEFAULT_ESCAPE_CHARACTER, CSVWriter.DEFAULT_LINE_END);
            writer.writeAll(data);
            System.out.println("数据写入成功");
        } catch (Exception e) {
            System.out.println("将数据写入CSV出错:"+e);
        } finally {
            if (null != writer) {
                try {
                    writer.flush();
                    writer.close();
                } catch (IOException e) {
                    System.out.println("关闭文件输出流出错:"+e);
                }
            }
        }
    }
    private static ArrayList<Domain> readCSV() {
        ArrayList<Domain> list=new ArrayList<>();
        InputStreamReader inputStreamReader;
        try {
            inputStreamReader = new InputStreamReader(new FileInputStream("C:\\Users\\wyq\\Desktop\\test1.csv"));
            Scanner inputStream = new Scanner(inputStreamReader);
            inputStream.nextLine(); // 第一行表头不要
            while (inputStream.hasNext()) {
                String data = inputStream.nextLine().replace(" ",""); // 得到一行数据
                String[] line = data.split(","); // 分割数据
                if (line.length>0){
                    Domain domain=new  Domain();
                    domain.setScqy(line[0]);
                    domain.setCpdl(line[1]);
                    domain.setCpxl(line[2]);
                    domain.setCpph(line[3]);
                    domain.setXqjhsl(line[4]);
                    domain.setQdck(line[5]);
                    domain.setDccf(line[6]);
                    domain.setCkmax(line[7]);
                    domain.setJhsj(line[8]);
                    domain.setDrpcbh(line[9]);
                    domain.setCkl(line[10]);
                    domain.setRkl(line[11]);
                    domain.setQckc(line[12]);
                    domain.setZtkc(line[13]);
                    domain.setKskcl(line[14]);
                    domain.setYswf(line[15]);
                    domain.setRksj(line[16]);
                    domain.setCksj(line[17]);
                    if (line.length > 18) {
                        domain.setZtcpyqddq(line[18]);
                    }
                    list.add(domain);
                }
            }
            inputStream.close();
            System.out.println("数据读取成功");
            return list;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}


相关文章
|
1月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
74 9
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
76 2
|
17天前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
81 34
|
1月前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
42 3
|
1月前
|
Java 测试技术 Maven
Maven clean 提示文件 java.io.IOException
在使用Maven进行项目打包时,遇到了`Failed to delete`错误,尝试手动删除目标文件也失败,提示`java.io.IOException`。经过分析,发现问题是由于`sys-info.log`文件被其他进程占用。解决方法是关闭IDEA和相关Java进程,清理隐藏的Java进程后重新尝试Maven clean操作。最终问题得以解决。总结:遇到此类问题时,可以通过任务管理器清理相关进程或重启电脑来解决。
|
1月前
|
存储 缓存 安全
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见。本文介绍了使用 `File.createTempFile` 方法和自定义创建临时文件的两种方式,详细探讨了它们的使用场景和注意事项,包括数据缓存、文件上传下载和日志记录等。强调了清理临时文件、确保文件名唯一性和合理设置文件权限的重要性。
96 2
|
1月前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
58 4
|
1月前
|
Java
springboot将list封装成csv文件
springboot将list封装成csv文件
40 4
|
1月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
70 4
|
1月前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
50 5