【转载】 Java导入导出CSV文件,使用commons-csv
转自
https://blog.csdn.net/m0_38084879/article/details/103458563
废话不多说,直接上代码。但在上代码之前,首先需要准备一个csv文件,放入“D:/CSV”目录下,供导入解析数据使用。
- 首先添加依赖
<!--导出CSV文件使用-->
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-csv -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-csv</artifactId>
<version>1.6</version>
</dependency>
- Java代码
package com.example.demo.Util;
import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVParser;
import org.apache.commons.csv.CSVPrinter;
import org.apache.commons.csv.CSVRecord;
import java.io.*;
import java.util.Date;
import java.util.List;
/**
* @Description TODO
* @Author wangs
* @Date 2019/12/5 17:01
*/
public class CSVUtil {
/**
* 导出
*/
public static void exportCsv() throws IOException {
File file =new File("D:/CSV");
//判断路径是否存在,不存在则创建
if(!file.exists()){
file.mkdirs();
}
Appendable printWriter = new PrintWriter(file+"/wangs.csv","GBK");
CSVPrinter csvPrinter = CSVFormat.EXCEL.withHeader("姓名", "性别", "年龄", "生日").print(printWriter);
for (int i = 0; i < 10; i++) {
csvPrinter.printRecord("lcf" + i, "M" + i, 18 + i, new Date());
}
csvPrinter.flush();
csvPrinter.close();
}
public static void importCsv()throws IOException{
InputStream inputStream =new FileInputStream("D:/CSV/导入.csv");//指定导入文件
InputStreamReader inputStreamReader =new InputStreamReader(inputStream,"GBK");
Reader reader = new BufferedReader(inputStreamReader);
//指定csv的标题头
CSVParser csvParser =CSVFormat.EXCEL.withHeader("name","sex","age","birthday").parse(reader);
//将每一行记录存入list中
List<CSVRecord> list = csvParser.getRecords();
//变量循环list
for(int i=0;i<list.size();i++){
System.out.println(list.get(i).get("name")+":"+list.get(i).get("sex")+":"+list.get(i).get("age")+":"+list.get(i).get("birthday"));
}
}
public static void main(String[] args) {
try {
CSVUtil.exportCsv();
CSVUtil.importCsv();
}catch (Exception e){
}
}
}
博 主 :夏秋初
地 址 :https://www.cnblogs.com/xiaqiuchu/articles/15228390.html
如果对你有帮助,可以点一下 推荐 或者 关注 吗?会让我的分享变得更有动力~
转载时请带上原文链接,谢谢。
地 址 :https://www.cnblogs.com/xiaqiuchu/articles/15228390.html
如果对你有帮助,可以点一下 推荐 或者 关注 吗?会让我的分享变得更有动力~
转载时请带上原文链接,谢谢。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义