CSV操作(导出和导入)【工具包系列】

CSV的导入导出经常用在数据库方面,比如在项目运作中,第三方的提供部分数据但是又不肯开放接口给调用者,他们只提供数

据库片段数据然后以CSV的格式提供给使用者,所以这个时候就是用到CSV导入导出的功能了,再提一下CSV的导入和导出功能

和TXT的导入导出功能非常相似,下一篇将介绍TXT的导入导出。那我们就直接来看代码吧,没什么难点,注意好流的关闭和异

常处理就好。

package com.lwl.util;

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

/**
 * CSV操作(导出和导入)
 * @author liuweilong@zhicall.com  
 * @create 2016-4-27 上午9:47:27
 * @version 1.0
 */
public class CSVUtils {

	/**
	 * 导出
	 * @param file csv文件(路径+文件名),csv文件不存在会自动创建
	 * @param dataList  数据
	 * @param heads  表头
	 * @return
	 * @author liuweilong@zhicall.com  
	 * @create 2016-4-27 上午9:49:49
	 */
	 public static boolean exportCsv(File file, List<String> dataList,String heads){
		 FileOutputStream out=null;
		  try {
			out = new FileOutputStream(file);
			return exportCsvByOS(out, dataList, heads);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
			return false;
		}
		 
	 }
	
	/**
	 * 导出
	 * @param out 输出流
	 * @param dataList  数据
	 * @param heads  表头
	 * @return
	 * @author liuweilong@zhicall.com  
	 * @create 2016-4-27 上午9:49:49
	 */
	 public static boolean exportCsvByOS(OutputStream out, List<String> dataList,String heads){
	        boolean isSucess=false;
	        
	        OutputStreamWriter osw=null;
	        BufferedWriter bw=null;
	        try {
	            osw = new OutputStreamWriter(out);
	            bw =new BufferedWriter(osw);
	            //循环表头
	            if(heads!=null&&!heads.equals("")){
	            	 bw.append(heads).append("\r");
	            }
	            //循环数据
	            if(dataList!=null && !dataList.isEmpty()){
	                for(String data : dataList){
	                    bw.append(data).append("\r");
	                }
	            }
	            isSucess=true;
	        } catch (Exception e) {
	        	e.printStackTrace();
	            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;
	    }

	 
	/**
	 *	测试 
	 * @param args
	 * @author liuweilong@zhicall.com  
	 * @create 2016-4-27 上午10:11:46
	 */
	 public static void main(String[] args) {
		 //导出数据测试
//		 List<String> dataList=new ArrayList<String>();
//	        dataList.add("1,张三,男");
//	        dataList.add("2,李四,男");
//	        dataList.add("3,小红,女");
//	        File file = new File("E:/test");
//	        if(!file.exists()){
//	        	file.mkdir();
//	        }
//	        boolean isSuccess=CSVUtils.exportCsv(new File("E:/test/ljq.csv"), dataList,"编码,姓名,性别");
//	        System.out.println(isSuccess);
	        
	    //导入数据测试   
		 
		 List<String> dataList= CSVUtils.importCsv(new File("E:/test/ljq.csv"));
		 for (String string : dataList) {
			System.out.println(string);
		}
		
		
	}
	 
}

代码很简单,而且已经给出测试用例,直接贴近项目即可使用。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MySQL 是一种流行的开源关系型数据库管理系统,它可以通过多种方式来导出导入数据表。Navicat 是一款常用的 MySQL 数据库管理工具,它提供了用户友好的界面和丰富的功能。 在 Navicat 中导出数据表,首先需要在导航栏中选择相应的数据库连接,然后展开数据库列表,选择要导出的数据库。接下来,右键点击要导出的数据表,选择“导出表”选项。在弹出的对话框中,选择导出的格式(如 SQL 文件、Excel 文件等)和文件路径,点击“确定”即可开始导出导出的文件将包含指定数据表的结构和数据。 在 Navicat 中导入数据表,同样需要选中要导入数据表的数据库连接。接着,右键点击数据库,选择“新建数据表”选项。在弹出的界面中,可以手动创建数据表的结构,也可以选择使用已存在的结构文件或从 CSV 文件中导入数据。如果选择使用已存在的结构文件,可以浏览文件并选择需要导入的结构文件。如果选择从 CSV 文件导入数据,则需要浏览并选择对应的 CSV 文件,并指定导入选项(如字段分隔符、行分隔符等)。最后,点击“确定”即可开始导入数据表。 总结而言,Navicat 是一个功能强大且易于使用的工具,可以方便地导出导入 MySQL 数据表。通过简单的几步操作,用户可以轻松地导出指定数据表的结构和数据,以及导入已有的结构文件或从 CSV 文件中导入数据。这些功能的使用可以大大提高数据库管理的效率和便利性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值