全网整合营销服务商

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

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

java如何生成可变表头的excel

本文为大家分享了java生成可变表头excel的具体步骤,供大家参考,具体内容如下

1、实现功能:

  传入一个表头和数据,将数据导入到excel中。

  为了便于项目的扩展,数据传入通过泛型集合传入,获取数据时,通过反射的方式获取,这样无论你的表头是多少项,我都能很方便的生成。另外为了便于数据的管理,我每天都会自动生成一个文件夹,excel生成在相应的文件夹中。文件的根目录通过读取项目中的properties文件获取(详情可查看:获取tomcat上properties文件内容的方法)。好啦,接下来直接进入代码开发吧。

2、所需jar包

  这里使用的是通过poi的方式将数据导入到excel中。

3、代码设计

1)、properties文件内容

filePath=E\:/appData 

2)、获取文件保存的根目录(来自项目中的properties文件)

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

public class GetFilePlace 
{
 /**
  * 读取文件,获取excel保存的根目录
  * @return excel保存的根目录
  */
 public String getFilePath()
 {
  String dir = System.getProperty("user.dir"); //获得tomcat所在的工作路径 
  
  //获取到存储了文件存储位置的filedir.properties 文件路径
  String realDir = dir + File.separator + "src" + File.separator +"META-INF" + File.separator + "filedir.properties";
  
  /*String realDir = dir.substring(0, dir.length()-4) + File.separator +"webapps" + File.separator + "generateExcels" 
      + File.separator + "classes" + File.separator + "META-INF" + File.separator + "config" + File.separator + "filedir.properties";
 */
  return realDir;
 }
 
 /**
  * 获取filePath路径【properities文件】中key对应的值,
  * @param filePath properities文件路径【包含properities文件】
  * @param key 要查找的key值
  * @return key对应的value
  */
  public String GetValueByKey(String filePath, String key) 
  {
   Properties pps = new Properties();
   try {
    InputStream in = new BufferedInputStream (new FileInputStream(filePath)); 
    pps.load(in);
    String value = pps.getProperty(key);
    in.close();
    return value;
    
   }catch (IOException e) {
    e.printStackTrace();
    return null;
   }
  }
 
 /**
  * 查询properities文件中可以对应的存储地点
  * @param key 查询主键
  * @return key对应的存储地址
  */
 public String getFileDirFromProperties(String key)
 {
  return GetValueByKey(getFilePath(),key);
 }
 
 public static void main(String[] args)
 {
  System.out.println(new GetFilePlace().getFileDirFromProperties("filePath"));
 }
}

3)、生成文件夹

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class GenerateFold
{
 /**
  * 查询当前生成的excel需要存在在哪个路径,如果存在则存储在相应的位置,否则生成改目录, 每天生成一个文件夹,文件夹的命名规则为 年月日的时间戳
  * @param foldName 生成excel保存路径
  * @return   现在的excel需要保存路径
  */
 public String getFold(String foldName)
 {
  SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");
  
  String todayStr = format.format(Calendar.getInstance().getTime());
  
  String foldPath = foldName + File.separator + todayStr; 
  
  File file = new File(foldPath);
  
  if(!file.exists() && !file.isDirectory())
  {
   System.out.println("不存在");
   file.mkdirs();
  }
  else
  {
   System.out.println("存在");
  }
  return foldPath;
 }

}

4)、生成excel

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;
import java.util.UUID;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.Region;
import org.apache.poi.ss.usermodel.CellStyle;

import com.zcr.until.GetFilePlace;
import com.zcr.until.User;

/**
 * 生成excel
 * @author zcr
 *
 */
public class GenerateExcel
{
 /**
  * 通过关键字查询properties文件相应文件的存储位置,根据表头顺序将数据保存到相应文件路径的xls文件中, 文件的命名规则是时间戳加一串全球唯一编码
  * @param fileDir       //查找文件存储根目录
  * @param head       //表头
  * @param list       //数据
  * @return        //文件的保存路径及其名字的字符串
  */
 public <T> String generateExcels(String fileDir,String [] head,List<T> list) 
 {
  //获得存储的路径
  //String savePath = new GetFilePlace().getFileDirFromProperties(key);
  
  //文件存储名字
  String saveFileName = "";
  SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmssSS");
  saveFileName += format.format(Calendar.getInstance().getTime());
  
  UUID uuid = UUID.randomUUID(); //全球唯一编码
  
  saveFileName += "-" + uuid.toString();
  
  
  HSSFWorkbook workbook = new HSSFWorkbook();
  HSSFSheet sheet = workbook.createSheet();
  workbook.setSheetName(0,"APP数据"); //设置表格工作簿名称
  HSSFCellStyle cellStyle = workbook.createCellStyle();
  cellStyle.setAlignment(CellStyle.ALIGN_CENTER);
  cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
  
  HSSFRow titleRow = sheet.createRow(0);
  sheet.addMergedRegion(new Region(0,(short)0,0,(short)(head.length-1)));
  HSSFCell titleCell = titleRow.createCell(0);
  titleCell.setCellValue("AAP数据____ ");
  titleCell.setCellStyle(cellStyle);
  HSSFRow row1 = sheet.createRow(1);
  
  
  //设置表头
  for(int i = 0 ; i < head.length ; i++)
  {
   HSSFCell cell = row1.createCell(i);
   cell.setCellValue(head[i]); //设置值
   cell.setCellStyle(cellStyle);//设置样式
  }
  
  
  if(null != list && list.size() > 0)
  {
   int size = list.size(); 
   Class classType = list.get(0).getClass();
   for(int i = 0,rowNum=2 ; i < size ; i ++,rowNum++)
   {
    HSSFRow rows = sheet.createRow(rowNum);
    T t = list.get(i);
    
    //添加数据行
    for(int j = 0 ; j < head.length ; j++) 
    {
     //获得首字母
     String firstLetter = head[j].substring(0,1).toUpperCase(); 
     
     //获得get方法,getName,getAge等
     String getMethodName = "get" + firstLetter + head[j].substring(1);
     
     Method method;
     try
     {
      //通过反射获得相应的get方法,用于获得相应的属性值
      method = classType.getMethod(getMethodName, new Class[]{});
      
      HSSFCell dataCell = rows.createCell(j);
      try
      {
        System.out.print(getMethodName +":" + method.invoke(t, new Class[]{}) +",");
        dataCell.setCellValue(method.invoke(t, new Class[]{}).toString());
      }
      catch (IllegalArgumentException e)
      {
       e.printStackTrace();
      }
      catch (IllegalAccessException e)
      {
       e.printStackTrace();
      }
      catch (InvocationTargetException e)
      {
       e.printStackTrace();
      } //设置值
      dataCell.setCellStyle(cellStyle);//设置样式
     }
     catch (SecurityException e)
     {
      e.printStackTrace();
     }
     catch (NoSuchMethodException e)
     {
      e.printStackTrace();
     }
     
    }
    System.out.println();
   }
  }
  else
  {
   System.out.println("没有数据");
  }
  
  //获得文件存储路径
  //String fileDir = new GetFilePlace().getFileDirFromProperties(key);
  saveFileName += ".xls";
  String saveFilePathAndName = fileDir + File.separator + saveFileName;
  OutputStream out = null;
  try
  {
   out = new FileOutputStream(saveFilePathAndName);
   try
   {
    workbook.write(out);//保存文件
   }
   catch (IOException e)
   {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  catch (FileNotFoundException e)
  {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  finally
  {
   try
   {
    out.close();
   }
   catch (IOException e)
   {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  
  return saveFilePathAndName;
 }

 
 /**
  * 提供外界调用的接口,生成以head为表头,list为数据的excel
  * @param head //数据表头
  * @param list //数据
  * @return  //excel所在的路径
  */
 public <T> String generateExcel(String [] head,List<T> list)
 {
  final String FilePath = "filePath";
  String saveFilePathAndName = "";
 
  //获得存储的根目录
  String savePath = new GetFilePlace().getFileDirFromProperties(FilePath);
  
  //获得当天存储的路径
  String realSavePath = new GenerateFold().getFold(savePath);
  
  //生成excel并将存储的路径返回(包含文件名)
  saveFilePathAndName = generateExcels(realSavePath, head, list);
  
  return saveFilePathAndName;
 }
 
 
 public static void main(String[] args)
 {
  String [] head = {"name","sex","adress","height","age","jj"};
  
  List<User> list = new ArrayList<User>();
  User user1 = new User("zhangsan",1,1.1f,"北京","男","AA");
  User user2 = new User("lisi",22222,3.2f,"上海","女","BB");
  
  list.add(user1);
  list.add(user2);
  
  System.out.println(new GenerateExcel().generateExcel(head,list));
  //System.out.println(new GenerateExcel().generateExcels("E:\\appData\\20151104",head,list));
 }

}


5)、测试结果

生成了文件

  文件内容如下

properties文件读取可查看:获取tomcat上properties文件内容的方法

读取excel可查看:java使用POI批量导入excel数据的方法

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


# java  # 可变表头  # excel  # Java读取Excel文件内容的简单实例  # Java数据导入功能之读取Excel文件实例  # java读取excel文件并复制(copy)文件到指定目录示例  # java读取excel文件的两种方法  # Windows中使用Java生成Excel文件并插入图片的方法  # Java根据模板导出Excel报表并复制模板生成多个Sheet页  # java生成excel报表文件示例  # java后台利用Apache poi 生成excel文档提供前台下载示例  # Java通过apache poi生成excel实例代码  # Java实现读取及生成Excel文件的方法  # 的是  # 导入到  # 都能  # 所需  # 并将  # 不存在  # 大家分享  # 好啦  # 很方便  # 上海  # 北京  # 具体内容  # 自动生成  # 直接进入  # 大家多多  # 主键  # 首字母  # 当天  # 保存文件  # 夹中 


相关文章: 如何通过主机屋免费建站教程十分钟搭建网站?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  ppt制作免费网站有哪些,ppt模板免费下载网站?  建站主机类型有哪些?如何正确选型  如何配置IIS站点权限与局域网访问?  如何在宝塔面板中创建新站点?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  企业微网站怎么做,公司网站和公众号有什么区别?  香港服务器选型指南:免备案配置与高效建站方案解析  简历在线制作网站免费,免费下载个人简历的网站是哪些?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何通过.red域名打造高辨识度品牌网站?  如何在建站之星绑定自定义域名?  如何打造高效商业网站?建站目的决定转化率  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何在云服务器上快速搭建个人网站?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?    Python lxml的etree和ElementTree有什么区别  学校建站服务器如何选型才能满足性能需求?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  建站主机无法访问?如何排查域名与服务器问题  阿里云网站制作公司,阿里云快速搭建网站好用吗?  如何在阿里云虚拟服务器快速搭建网站?  建站主机SSH密钥生成步骤及常见问题解答?  详解jQuery停止动画——stop()方法的使用  如何用西部建站助手快速创建专业网站?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  智能起名网站制作软件有哪些,制作logo的软件?  深圳网站制作培训,深圳哪些招聘网站比较好?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何零基础在云服务器搭建WordPress站点?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  建站主机选购指南与交易推荐:核心配置解析  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  手机网站制作与建设方案,手机网站如何建设?  如何用y主机助手快速搭建网站?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  教程网站设计制作软件,怎么创建自己的一个网站?  建站主机是否等同于虚拟主机?  如何选择高效响应式自助建站源码系统?  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  如何基于PHP生成高效IDC网络公司建站源码?  Swift中循环语句中的转移语句 break 和 continue  广州美橙建站如何快速搭建多端合一网站? 

您的项目需求

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