Java导入导出CSV文件

场景:导入导出CSV文件

1、CSVUtils类

package com.delta.gddx;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.List;

public class CSVUtils {
	/**
     * 导出
     * 
     * @param file csv文件(路径+文件名),csv文件不存在会自动创建
     * @param dataList 数据
     * @return
     */
    public static boolean exportCsv(File file, List<String> dataList){
        boolean isSucess=false;
        FileOutputStream out=null;
        OutputStreamWriter osw=null;
        BufferedWriter bw=null;
        try {
            out = new FileOutputStream(file);
            osw = new OutputStreamWriter(out);
            bw =new BufferedWriter(osw);
            if(dataList!=null && !dataList.isEmpty()){
                for(String data : dataList){
                    bw.append(data).append("\r");
                }
            }
            isSucess=true;
        } catch (Exception e) {
            isSucess=false;
        }finally{
            if(bw!=null){
                try {
                    bw.close();
                    bw=null;
                } catch (IOException e) {
                    e.printStackTrace();
                } 
            }
            if(osw!=null){
                try {
                    osw.close();
                    osw=null;
                } catch (IOException e) {
                    e.printStackTrace();
                } 
            }
            if(out!=null){
                try {
                    out.close();
                    out=null;
                } catch (IOException e) {
                    e.printStackTrace();
                } 
            }
        }
        
        return isSucess;
    }
    
    /**
     * 导入
     * 
     * @param file csv文件(路径+文件)
     * @return
     */
    public static List<String> importCsv(File file){
        List<String> dataList=new ArrayList<String>();
        
        BufferedReader br=null;
        try { 
            br = new BufferedReader(new FileReader(file));
            String line = ""; 
            while ((line = br.readLine()) != null) { 
                dataList.add(line);
            }
        }catch (Exception e) {
        }finally{
            if(br!=null){
                try {
                    br.close();
                    br=null;
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
 
        return dataList;
    }
}

2、FeatureHandle测试类:

package com.delta.gddx;

import java.io.File;
import java.util.List;

public class FeatureHandle {
	public static void main(String args[]){
		
		File file =new File("D:\\test.csv");
		List<String> lstrs= CSVUtils.importCsv(file);
		for(String str:lstrs){
			System.out.println(str);
		}
		
		File ofile=new File("D:\\testo.csv");
		CSVUtils.exportCsv(ofile, lstrs);
	}
}


  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用以下步骤在 Java导入导出 CSV 文件导入 CSV 文件: 1. 创建一个 BufferedReader 对象,用于从 CSV 文件中读取数据。 2. 读取 CSV 文件中的每一行数据,并将其分割为字段。 3. 将每个字段转换为相应的数据类型,并将其存储在相应的变量中。 导出 CSV 文件: 1. 创建一个 FileWriter 对象,用于将数据写入 CSV 文件中。 2. 将数据按照 CSV 格式写入文件中,每个字段之间用逗号分隔,每个记录之间用换行符分隔。 以下是一个简单的示例代码,演示如何在 Java导入导出 CSV 文件导入 CSV 文件示例代码: ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; public class CSVReader { public static void main(String[] args) { String csvFile = "data.csv"; String line = ""; String cvsSplitBy = ","; try (BufferedReader br = new BufferedReader(new FileReader(csvFile))) { while ((line = br.readLine()) != null) { String[] data = line.split(cvsSplitBy); // 处理 CSV 数据 // ... } } catch (IOException e) { e.printStackTrace(); } } } ``` 导出 CSV 文件示例代码: ```java import java.io.FileWriter; import java.io.IOException; public class CSVWriter { public static void main(String[] args) { String csvFile = "data.csv"; String csvData = "1,John,Doe\n2,Jane,Doe\n3,Bob,Smith"; try (FileWriter writer = new FileWriter(csvFile)) { writer.write(csvData); } catch (IOException e) { e.printStackTrace(); } } } ``` 在实际的应用中,需要根据实际需求进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值