java导出生成csv文件的方法

 更新时间:2020年12月31日 11:19:54   作者:FlyHeLanMan  
这篇文章主要为大家详细介绍了java导出生成csv文件的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了java导出生成csv文件的具体代码,供大家参考,具体内容如下

首先我们需要对csv文件有基础的认识,csv文件类似excel,可以使用excel打开,但是csv文件的本质是逗号分隔的,对比如下图:

txt中显示:

修改文件后缀为csv后显示如下:

在java中我们一般使用poi操作excel,导入,导出都可以,但是poi很消耗内存,尤其在导出时,这个时候我们其实可以选择导出生成csv文件,因为其跟文本差不多,所以效率很高。

简单写了一个实现类,代码如下:

/**
  *    
  *     导出生成csv格式的文件
  * @author   ccg
  * @param   titles csv格式头文
  * @param   propertys 需要导出的数据实体的属性,注意与title一一对应
  * @param   list 需要导出的对象集合
  * @return
  * @throws   IOException
  * Created   2017年1月5日 上午10:51:44
  * @throws   IllegalAccessException 
  * @throws   IllegalArgumentException 
  */
 public static <T> String exportCsv(String[] titles,String[] propertys,List<T> list) throws IOException, IllegalArgumentException, IllegalAccessException{
  File file = new File("d:\\test.csv");
  //构建输出流,同时指定编码
  OutputStreamWriter ow = new OutputStreamWriter(new FileOutputStream(file), "gbk");
  
  //csv文件是逗号分隔,除第一个外,每次写入一个单元格数据后需要输入逗号
  for(String title : titles){
   ow.write(title);
   ow.write(",");
  }
  //写完文件头后换行
  ow.write("\r\n");
  //写内容
  for(Object obj : list){
   //利用反射获取所有字段
   Field[] fields = obj.getClass().getDeclaredFields();
   for(String property : propertys){
    for(Field field : fields){
     //设置字段可见性
     field.setAccessible(true); 
     if(property.equals(field.getName())){
      ow.write(field.get(obj).toString());
      ow.write(",");
      continue;
     }
    }
   }
   //写完一行换行
   ow.write("\r\n");
  }
  ow.flush();
  ow.close();
  return "0";
 }

测试类如下:

public void test() throws IOException, IllegalArgumentException, IllegalAccessException{
  String[] titles = new String[]{"ID","姓名"};
  String[] propertys = new String[]{"id","name"};
  List<User> list = new ArrayList<User>();
  User user;
  user = new User();
  user.setId(1L);
  user.setName("张三");
  list.add(user);
  user = new User();
  user.setId(2L);
  user.setName("李四");
  list.add(user);
  CsvUtil.getInstance().exportCsv(titles,propertys, list);
 }

导出后生成的文件跟上图一样,算是一个封装吧,传入表头,以及表头对应实体的属性即可,注意要一一对应。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java详细讲解包的作用以及修饰符的介绍

    Java详细讲解包的作用以及修饰符的介绍

    本文主要讲述的是包的使用和注意事项和四种访问修饰符public,protected,默认的,private的访问范围及实例,感兴趣的朋友一起来看看
    2022-05-05
  • Java模仿微信实现零钱通简易功能(两种版本)

    Java模仿微信实现零钱通简易功能(两种版本)

    本文主要介绍了使用Java开发零钱通项目, 模仿微信实现简易功能,可以完成收益入账,消费,查看明细,退出系统等功能。文中一共介绍了两种实现方法,快来学习吧
    2021-12-12
  • 如何使用Spring Security实现用户-角色-资源的权限控制

    如何使用Spring Security实现用户-角色-资源的权限控制

    文章介绍了如何通过SpringSecurity实现用户-角色-资源的权限管理,包括基于角色的请求控制、加载用户角色信息、角色与资源的关联等步骤,同时,提供了一些测试场景,以验证权限控制是否正确,感兴趣的朋友跟随小编一起看看吧
    2024-10-10
  • 深入探究Java线程的创建与构造方法

    深入探究Java线程的创建与构造方法

    这篇文章主要给大家分享的是java线程的创建以及构造方法,想了解具体方式的小伙伴可以参考下面文章内容,希望对你有所帮助
    2022-04-04
  • 23种设计模式(17)java命令模式

    23种设计模式(17)java命令模式

    这篇文章主要为大家详细介绍了23种设计模式之java命令模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • 一篇文章带你了解Java Stream流

    一篇文章带你了解Java Stream流

    Stream流是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。这篇文章主要介绍了Java8新特性Stream流的相关资料,需要的朋友参考下吧
    2021-08-08
  • Kotlin null的处理详解

    Kotlin null的处理详解

    这篇文章主要介绍了Kotlin null的处理详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Java实现后台发送及接收json数据的方法示例

    Java实现后台发送及接收json数据的方法示例

    这篇文章主要介绍了Java实现后台发送及接收json数据的方法,结合实例形式分析了java针对json格式数据的传输与操作相关技巧,需要的朋友可以参考下
    2018-12-12
  • 基于java内部类作用的深入分析

    基于java内部类作用的深入分析

    本篇文章介绍了,基于java内部类作用的深入分析。需要的朋友参考下
    2013-05-05
  • hadoop的wordcount实例代码

    hadoop的wordcount实例代码

    这篇文章主要介绍了hadoop的wordcount实例代码,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2018-02-02

最新评论