zoukankan      html  css  js  c++  java
  • 如何生成可变表头的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

  • 相关阅读:
    LeetCode 141. Linked List Cycle(判断链表是否有环)
    LeetCode 680. Valid Palindrome II(双指针)
    >/dev/null 2>&1
    18个最佳代码编辑器
    vi和vim常用命令
    搞定Windows连Linux三大件:SecureCRT,FileZilla,NX
    define和typedef的区别
    C++ const,static成员
    C++虚函数练习题
    c++虚函数解析
  • 原文地址:https://www.cnblogs.com/softidea/p/4950750.html
Copyright © 2011-2022 走看看