热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

JAVA导出CSV文件实例教程

这篇文章主要介绍了如何用JAVA导出CSV文件,文中案例代码十分详细,对大家的学习有所帮助,感兴趣的朋友可以了解下

以前导出总是用POI导出为Excel文件,后来当我了解到CSV以后,我发现速度飞快。

如果导出的数据不要求格式、样式、公式等等,建议最好导成CSV文件,因为真的很快。

虽然我们可以用Java再带的文件相关的类去操作以生成一个CSV文件,但事实上有好多第三方类库也提供了类似的功能。

这里我们使用apache提供的commons-csv组件

Commons CSV

文档在这里

http://commons.apache.org/

http://commons.apache.org/proper/commons-csv/

http://commons.apache.org/proper/commons-csv/user-guide.html

先看一下具体用法

@Test public void testWrite() throws Exception {
  FileOutputStream fos = new FileOutputStream("E:/cjsworkspace/cjs-excel-demo/target/abc.csv");
  OutputStreamWriter osw = new OutputStreamWriter(fos, "GBK");

  CSVFormat csvFormat = CSVFormat.DEFAULT.withHeader("姓名", "年龄", "家乡");
  CSVPrinter csvPrinter = new CSVPrinter(osw, csvFormat);//  csvPrinter = CSVFormat.DEFAULT.withHeader("姓名", "年龄", "家乡").print(osw);

  for (int i = 0; i <10; i++) {
   csvPrinter.printRecord("张三", 20, "湖北");
  }

  csvPrinter.flush();
  csvPrinter.close();

 }

 @Test public void testRead() throws IOException {
  InputStream is = new FileInputStream("E:/cjsworkspace/cjs-excel-demo/target/abc.csv");
  InputStreamReader isr = new InputStreamReader(is, "GBK");
  Reader reader = new BufferedReader(isr);

  CSVParser parser = CSVFormat.EXCEL.withHeader("name", "age", "jia").parse(reader);//  CSVParser csvParser = CSVParser.parse(reader, CSVFormat.DEFAULT.withHeader("name", "age", "jia"));
  List list = parser.getRecords();  for (CSVRecord record : list) {
   System.out.println(record.getRecordNumber()     + ":" + record.get("name")     + ":" + record.get("age")     + ":" + record.get("jia"));
  }

  parser.close();
 } /**
  * Parsing an Excel CSV File  */
 @Test public void testParse() throws Exception {
  Reader reader = new FileReader("C:/Users/Administrator/Desktop/abc.csv");
  CSVParser parser = CSVFormat.EXCEL.parse(reader);  for (CSVRecord record : parser.getRecords()) {
   System.out.println(record);
  }
  parser.close();
 } /**
  * Defining a header manually  */
 @Test public void testParseWithHeader() throws Exception {
  Reader reader = new FileReader("C:/Users/Administrator/Desktop/abc.csv");
  CSVParser parser = CSVFormat.EXCEL.withHeader("id", "name", "code").parse(reader);  for (CSVRecord record : parser.getRecords()) {
   System.out.println(record.get("id") + ","
     + record.get("name") + ","
     + record.get("code"));
  }
  parser.close();
 } /**
  * Using an enum to define a header  */
 enum MyHeaderEnum {
  ID, NAME, CODE;
 }

 @Test public void testParseWithEnum() throws Exception {
  Reader reader = new FileReader("C:/Users/Administrator/Desktop/abc.csv");
  CSVParser parser = CSVFormat.EXCEL.withHeader(MyHeaderEnum.class).parse(reader);  for (CSVRecord record : parser.getRecords()) {
   System.out.println(record.get(MyHeaderEnum.ID) + ","
     + record.get(MyHeaderEnum.NAME) + ","
     + record.get(MyHeaderEnum.CODE));
  }
  parser.close();
 } private List> recordList = new ArrayList<>();

 @Before public void init() {  for (int i = 0; i <5; i++) {
   Map map = new HashMap<>();
   map.put("name", "zhangsan");
   map.put("code", "001");
   recordList.add(map);
  }
 }

 @Test public void writeMuti() throws InterruptedException {
  ExecutorService executorService = Executors.newFixedThreadPool(3);
  CountDownLatch dOneSignal= new CountDownLatch(2);

  executorService.submit(new exprotThread("E:/0.csv", recordList, doneSignal));
  executorService.submit(new exprotThread("E:/1.csv", recordList, doneSignal));

  doneSignal.await();
  System.out.println("Finish!!!");
 } class exprotThread implements Runnable {  private String filename;  private List> list;  private CountDownLatch countDownLatch;  public exprotThread(String filename, List> list, CountDownLatch countDownLatch) {   this.filename = filename;   this.list = list;   this.countDownLatch = countDownLatch;
  }

  @Override  public void run() {   try {
    CSVPrinter printer = new CSVPrinter(new FileWriter(filename), CSVFormat.EXCEL.withHeader("NAME", "CODE"));    for (Map map : list) {
     printer.printRecord(map.values());
    }
    printer.close();
    countDownLatch.countDown();
   } catch (IOException e) {
    e.printStackTrace();
   }
  }
 }

CSV与EXCEL

  /**
  * 测试写100万数据需要花费多长时间  */
 @Test public void testMillion() throws Exception {  int times = 10000 * 10;
  Object[] cells = {"满100减15元", "100011", 15};  // 导出为CSV文件
  long t1 = System.currentTimeMillis();
  FileWriter writer = new FileWriter("G:/test1.csv");
  CSVPrinter printer = CSVFormat.EXCEL.print(writer);  for (int i = 0; i 

Maven依赖


 
  org.apache.commons
  commons-csv
  1.5
 

 
  org.apache.poi
  poi
  3.17
 

 
  org.apache.poi
  poi-ooxml
  3.17
 


 
  junit
  junit
  4.12
  test
 

最后,刚才的例子中只写了3个字段,100万行,生成的CSV文件有十几二十兆,太多的话建议分多个文件打包下周,不然想象一个打开一个几百兆的excel都费劲。

以上就是JAVA导出CSV文件实例教程的详细内容,更多关于JAVA导出CSV文件的资料请关注其它相关文章!


推荐阅读
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 小程序服务器获取用户名头像,微信小程序wx.getUserInfo授权获取用户信息(头像、昵称)的实现...
    这个接口只能获得一些非敏感信息,例如用户昵称,用户头像,经过用户授权允许获取的情况下即可获得用户信息,至于openid这些& ... [详细]
  • 2月4日每日安全热点节日期间某企远程办公遭XRed攻击 ... [详细]
  • 上一章我们设置了分类页面的页面标签,这一章我们继续标签设置格局。话不多说标签设置格局,我们一起操练起来吧~ ... [详细]
  • 利用POI 从Excel取图,自动制作PPT
    Excel中的模版是这样的一个PNG或者jpg另外有一段表格如图首先呢,我们会想到poi这个工具然后我的思路是先把图片取出来,然后利用G2P将表格画出 ... [详细]
author-avatar
iflbicfb_6114756
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有