本文为大家分享了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 String generateExcels(String fileDir,String [] head,List 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 String generateExcel(String [] head,List 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 list = new ArrayList();

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)、测试结果

生成了文件

文件内容如下

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

java 动态表头_java如何生成可变表头的excel相关推荐

  1. java 动态字符串_Java动态编译执行一串字符串,类似于Javascript里的eval函数

    Javascript里的eval函数能动态执行一串js脚本. 那Java里怎么做到呢. 有两种方法: 一种是使用可以执行js脚本的Java类 ScriptEngineManagerpublic sta ...

  2. java动态代理_Java动态代理

    java动态代理 代理是一种设计模式. 当我们想添加或修改现有类的某些功能时,我们创建并使用代理对象. 使用代理对象而不是原始对象. 通常,代理对象具有与原始对象相同的方法,并且在Java代理类中,通 ...

  3. java动态语言_java动态类型语言支持(三)

    invokedynamic指令 在前面java动态类型语言支持(一)(二)中我们有提到invokedynamic指令和java.lang.invoke包中的MethodHandle机制,在某种程度上他 ...

  4. java动态方法_Java 动态方法调用

    Java 动态方法调用 在Java中,如果方法重写只是一种名字空间的编写,那么它最多是让人感到有趣,但没有实际价值,但情况并非如此.方法重写构造成了Java最大的一个概念基础:动态方法调度(dynam ...

  5. java 动态数组_Java动态数组的用法详解

    Java动态数组是一种可以任意伸缩数组长度的对象,在Java中比较常用的是ArrayList,ArrayList是javaAPI中自带的java.util.ArrayList.下面介绍一下ArrayL ...

  6. 如何生成可变表头的excel

    1.实现功能: 传入一个表头和数据,将数据导入到excel中. 为了便于项目的扩展,数据传入通过泛型集合传入,获取数据时,通过反射的方式获取,这样无论你的表头是多少项,我都能很方便的生成.另外为了便于 ...

  7. java gif图片_java 如何生成动态的gif图片

    网上找了很多资料都没有生成gif图片的例子.但是生成水印的文件到不少,如果我们把gif图片合成水印后,图片就不动了,所以我写了个小例子供大家参考.(如果你想在某个图片上打印个动感图标,这个类就能很好地 ...

  8. java 动态 枚举_java 动态生成枚举值

    在某些场景下我们需要动态生成一些枚举值,主要是通过反射生成,但是这种生成枚举值是不能switch的 1.枚举值类 public enum CodeInfoEnum { LOCK(1L, 1L, &qu ...

  9. java动态代理_Java代理模式及动态代理详解

    Java的动态代理在实践中有着广泛的使用场景,比如最场景的Spring AOP.Java注解的获取.日志.用户鉴权等.本篇文章带大家了解一下代理模式.静态代理以及基于JDK原生动态代理. 代理模式 无 ...

最新文章

  1. Docker 入门到实践笔记2
  2. vue中引入第三方字体图标库iconfont,及iconfont引入彩色图标
  3. 算法提高课-图论-单源最短路的建图方式-AcWing 1126. 最小花费:dijkstra求最长路
  4. html5app大赛,Anyoffice -HTML5大赛 悦心(基于H5开发安卓音乐app)-项目总结
  5. jquery非常不错的图片切换,多种切换效果
  6. 计算机二级如何接受审阅者修订,操作方法 合并修订文档 步骤1 要求审阅者
  7. Ubuntu 16.04 安装CodeBlocks
  8. 求平均数、百分率、最大值、最小值、两个字段相差秒数的SQL
  9. oracle查询时根据查询的时间字段改变状态字段的值
  10. 实现树状结构_钢结构设计 | “生命之树”景观案例赏析
  11. Linux源码下Makefile详解(参照Documentation\kbuild\makefiles.txt和资料)-转
  12. orm框架设计、分析与开发
  13. 机器学习入门(三):神经网络起手式
  14. mysql1232_Mysql执行流程
  15. 3、SpringBoot集成Storm WorldCount
  16. 28款数据恢复软件分类介绍
  17. qsdk53:QCA9531+QCA9887生产无法校准问题分析及解决方案
  18. Unity URP/SRP可编程渲染管线
  19. 从百度指数到微信指数,我们正进入“数据世界”
  20. 【音视频处理】码率、帧率越高越清晰?分辨率、像素、dpi之间是什么关系?码率的真实作用,I帧、B帧、P帧是什么

热门文章

  1. NLP入门 - 基于Word Embedding + LSTM的古诗生成器
  2. java rsa 文件加密解密_RSA 加密、解密(自己生成加密解密文件)
  3. 有关H5第七章的盒子模型介绍
  4. 手机里android文件夹是什么文件夹,安卓手机里的.androidlmage test是什么文件夹?...
  5. 【图像修复】基于matlab损坏图像修复【含Matlab源码 731期】
  6. 如何解决oracle中文乱码问题,oracle中解决中文乱码问题
  7. Python还在原地踏步?今天女友程序员教你函数的定义与使用
  8. 解决Could not get a resource from the pool 异常问题
  9. python plc fx5u_三菱PLC FX5U系列模块型号对照一览表
  10. ios 中webView加载html文本图片显示不全