如何生成可变表头的excel(转)

1、实现功能:

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

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

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文件读取可查看:http://www.cnblogs.com/0201zcr/p/4700418.html

读取excel可查看:http://www.cnblogs.com/0201zcr/p/4656779.html

http://www.cnblogs.com/0201zcr/p/4950619.html

时间: 2024-10-07 15:20:15

如何生成可变表头的excel(转)的相关文章

单表头,多表头导出excel

一.单表头 1 #region 导出 2 if (this.dgvInfo.Rows.Count > 0) 3 { 4 SaveFileDialog saveFileDialog = new SaveFileDialog(); 5 saveFileDialog.DefaultExt = "xls"; 6 saveFileDialog.Filter = "EXCEL文件(*.XLS)|*.xls"; 7 saveFileDialog.FilterIndex =

JAVA操作Excel 可配置,动态 生成复杂表头 复杂的中国式报表表头

转载:开源社区http://www.oschina.net/code/snippet_1424099_49530?p=2代码] [Java]代码 该代码实现了Excel复杂表头的生成 基于sql server 的一张树表 你们可以 看代码自行建库 package com.jingjiu.util; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; i

poi 动态生成多表头execl

如果所示,我要导出的数据界面是下面这样的,前面样品编号.样品名称.炉次为主表数据,而检验结果是子表数据,这里子表的数据作为了主表的数据的一个字段(集合属性),下面代码会给大家看vo结构 下图为要导出的execl效果 开发思路: 1.该表头表体是根据主表样品名称不同而子表元素个数就会不同,所以第一步就是将前端传来的数据按样品名称分组 2.由于导出的数据顺序会乱,所以还是需要map排序下,这里我们可以按key排序 3.由于我要导出的数据是主子表结构,所以要将表体数据利用反射映射到表头去,以方便导出使

【C#附源码】数据库文档生成工具支持(Excel+Html)

[2015] 很多时候,我们在生成数据库文档时,使用某些工具,可效果总不理想,不是内容不详细,就是表现效果一般般.很多还是word.html的.看着真是别扭.本人习惯用Excel,所以闲暇时,就简单的编写了数据库文档生成工具,供大家交流学习之用,与程序员共勉.     该工具为C#控制台,以NPOI为基础,操作Excel.简单方便,简单配置.两次回车,OK!即可生成清晰的数据库文档.另外,支持生成HTML文档.源码大小7MB,OS上传不了,放到百度云盘里了:http://pan.baidu.co

NPOI操作EXCEL(五)——含合并单元格复杂表头的EXCEL解析

我们在第三篇文章中谈到了那些非常反人类的excel模板,博主为了养家糊口,也玩命做出了相应的解析方法... 我们先来看看第一类复杂表头: ...... 博主称这类excel模板为略复杂表头模板(蓝色部分为表头部分,蓝色前面几行是博主项目的基础样式,称为元数据),这类excel的表头多为2-3行,甚至于5/6行 ,具有合并层级关系,看似复杂,但只需要在我们以前的基础上稍微做一下重构就可以完美实现解析. 我们以各地区户籍人口城乡构成表头为例: 其实,只要我们能准确解析这类表头所表达的意思,就能复用以

silverlight RadGridView 复合表头 多表头 导出excel

ListHeaderShow.Clear(); ListHeaderShow.Add("区县"); ListHeaderShow.Add("企业名称"); ListHeaderShow.Add("监测点名称"); ListHeaderShow.Add("监测时间"); Util.Export<T_DATA_DATACOMMON> Exportxls = new Util.Export<T_DATA_DATAC

element UI实现动态生成多级表头

一.效果图 二.封装两个组件,分别为DynamicTable.vue和TableColumn.vue,TableColumn.vue主要是使用递归来对表头进行循环生成 DynamicTable.vue 1 <template> 2 <el-table :data="tableData" border :height="height"> 3 <template v-for="item in tableHeader"&g

javacsv生成的csv用excel打开中文乱码

在SourceForge上找到读写csv文件的开源代码. 但是生成的csv文件,如果用excel打开时,中文全部会乱码.原因是excel在解析csv文件时,默认以utf-8带BOM格式去解析的. utf-8保存的csv格式文件要让Excel正常打开的话,必须加入在文件最前面加入BOM(Byte order). 主要修改代码如下: private void checkInit() throws IOException { if (!initialized) { if (fileName != nu

Aspose.Cell 生成带水印的excel文件

1 private void ExportDataSet(string fileName, string templatePath, DataSet ds, HttpResponse reponse, FileFormatType FileType= FileFormatType.Xlsx) 2 { 3 Aspose.Cells.License Clicense = new Aspose.Cells.License(); 4 string asposePath = Server.MapPath(