全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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  # csv  # Javacsv实现Java读写csv文件  # 使用Javacsv.jar的jar包操作csv文件的方法  # Java生成CSV文件实例详解  # java读取csv文件和写csv示例分享  # java读取csv文件示例分享(java解析csv文件)  # java生成csv文件乱码的解决方法示例 java导出csv乱码  # 一文秒懂通过JavaCSV类库读写CSV文件的技巧  # 写完  # 换行  # 第一个  # 很高  # 写了  # 这个时候  # 为其  # 可以使用  # 可以选择  # 大家分享  # 具体内容  # 大家多多  # 如下图  # 上图  # 单元格  # 李四  # 上午  # 见性  # title  # list 


相关文章: 如何做静态网页,sublimetext3.0制作静态网页?  如何快速生成ASP一键建站模板并优化安全性?  如何做网站制作流程,*游戏网站怎么搭建?  个人摄影网站制作流程,摄影爱好者都去什么网站?  高防服务器如何保障网站安全无虞?  建站三合一如何选?哪家性价比更高?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  如何设置并定期更换建站之星安全管理员密码?  linux top下的 minerd 木马清除方法  如何用VPS主机快速搭建个人网站?  建站之星安装需要哪些步骤及注意事项?  临沂网站制作企业,临沂第三中学官方网站?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  如何快速生成凡客建站的专业级图册?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  XML的“混合内容”是什么 怎么用DTD或XSD定义  建站主机如何选?性能与价格怎样平衡?  建站之星代理如何获取技术支持?  如何快速配置高效服务器建站软件?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  如何通过远程VPS快速搭建个人网站?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  完全自定义免费建站平台:主题模板在线生成一站式服务  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  简单实现Android文件上传  如何在香港免费服务器上快速搭建网站?  建站之星安装提示数据库无法连接如何解决?  ,购物网站怎么盈利呢?  如何高效配置IIS服务器搭建网站?  如何通过虚拟主机快速完成网站搭建?  Thinkphp 中 distinct 的用法解析  如何快速搭建FTP站点实现文件共享?  如何在万网ECS上快速搭建专属网站?  C#如何在一个XML文件中查找并替换文本内容  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  网站制作公司,橙子建站是合法的吗?  如何在云服务器上快速搭建个人网站?  如何在阿里云高效完成企业建站全流程?  婚礼视频制作网站,学习*后期制作的网站有哪些?  韩国服务器如何优化跨境访问实现高效连接?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  建站之星云端配置指南:模板选择与SEO优化一键生成  如何实现建站之星域名转发设置?  重庆市网站制作公司,重庆招聘网站哪个好?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。