java将数据写入csv文件,从csv文件中读取数据

全栈工程师开发手册 (作者:栾鹏)

java教程全解

java将数据写入csv文件,从csv文件中读取数据

测试代码

	  public static void main(String[] arges){
		  //自定义数组
	      ArrayList<ArrayList<String>> alldata=new ArrayList<ArrayList<String>>();
	      alldata.add(new ArrayList<String>(Arrays.asList("1","11","111")));  //添加一行
	      alldata.add(new ArrayList<String>(Arrays.asList("2","22","222")));  //添加一行
	      alldata.add(new ArrayList<String>(Arrays.asList("3","33","333")));  //添加一行
	      //保存成csv文件
	      Array2CSV(alldata,"test.csv");
	      //读取csv文件
	      ArrayList<ArrayList<String>> alldata1=CSV2Array("test.csv");
	      //遍历数组
	      for (ArrayList<String> arrayList : alldata1) {
				for (String string : arrayList) {
					System.out.println(string);
				}
		  }
	  }

将数据写入csv文件

//导出到csv文件
      public static void Array2CSV(ArrayList<ArrayList<String>> data, String path)
      {
    	  try {
    		    BufferedWriter out =new BufferedWriter(new OutputStreamWriter(new FileOutputStream(path),"UTF-8"));			
	  			for (int i = 0; i < data.size(); i++)
	            {
	  				ArrayList<String> onerow=data.get(i);
	                for (int j = 0; j < onerow.size(); j++)
	                {
	                	out.write(DelQuota(onerow.get(j)));
	                	out.write(",");
	                }
	                out.newLine();
	            }
	  			out.flush();
	  			out.close();
  			
	  		} catch (Exception e) {
	  			e.printStackTrace();
	  		}
    	  
      }
      public static String DelQuota(String str)
      {
          String result = str;
          String[] strQuota = { "~", "!", "@", "#", "$", "%", "^", "&", "*", "(", ")", "`", ";", "'", ",", ".", "/", ":", "/,", "<", ">", "?" };
          for (int i = 0; i < strQuota.length; i++)
          {
              if (result.indexOf(strQuota[i]) > -1)
                  result = result.replace(strQuota[i], "");
          }
          return result;
      }

从csv文件中读取数据

 public static ArrayList<ArrayList<String>> CSV2Array(String path)
      {
    	  try {
    		  	BufferedReader in =new BufferedReader(new InputStreamReader(new FileInputStream(path),"UTF-8"));
	      	    ArrayList<ArrayList<String>> alldata=new ArrayList<ArrayList<String>>();
	  			String line;
	  			String[] onerow;
	  			while ((line=in.readLine())!=null) {
	  				 onerow = line.split(",");  //默认分割符为逗号,可以不使用逗号
	  				 List<String> onerowlist = Arrays.asList(onerow);
	  				 ArrayList<String> onerowaArrayList = new ArrayList<String>(onerowlist);
	  				 alldata.add(onerowaArrayList);
	  			}
	  			in.close();
                return alldata;
			} catch (Exception e) {
				return null;
			}
    	    
      }
  • 2
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
Java读取CSV文件数据写入MySQL可以通过以下步骤完成: 1. 首先,你需要使用Java的FileReader类来读取CSV文件。可以使用CSVReader或者BufferedReader来逐行读取CSV文件的内容。 2. 在读取CSV文件的同时,你可以使用StringTokenizer或者split方法将每一行数据拆分成字段,以便后续写入到MySQL。 3. 接下来,你需要使用Java的JDBC(Java Database Connectivity)来连接MySQL数据库。在连接数据库之前,你需要下载并添加数据库驱动程序(JDBC驱动)到你的Java项目。 4. 一旦连接到MySQL数据库,你可以使用PreparedStatement准备SQL语句,并使用setString或者setInt等方法设置参数的值,将数据插入到MySQL数据。 5. 最后,你可以通过执行PreparedStatement的executeUpdate方法来执行SQL插入语句,并将CSV文件数据写入到MySQL数据库表。 以下是一个简单的示例代码,用于读取CSV文件并将数据写入到MySQL数据库: import java.io.BufferedReader; import java.io.FileReader; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; public class CSVtoMySQLExample { public static void main(String[] args) { String csvFilePath = "path_to_csv_file.csv"; String jdbcURL = "jdbc:mysql://localhost:3306/db_name"; String username = "your_username"; String password = "your_password"; try (Connection connection = DriverManager.getConnection(jdbcURL, username, password); BufferedReader br = new BufferedReader(new FileReader(csvFilePath))) { String line; while ((line = br.readLine()) != null) { String[] data = line.split(","); String sql = "INSERT INTO table_name (column1, column2, column3) VALUES (?, ?, ?)"; PreparedStatement statement = connection.prepareStatement(sql); statement.setString(1, data[0]); statement.setString(2, data[1]); statement.setString(3, data[2]); statement.executeUpdate(); } System.out.println("Data imported successfully!"); } catch (Exception e) { e.printStackTrace(); } } } 请注意,以上代码仅作为示例,你需要根据你的实际情况修改数据库连接信息、CSV文件路径以及插入数据的SQL语句。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

腾讯数据架构师

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值