zoukankan      html  css  js  c++  java
  • poi导出excel

    /**
         * 文件下载
         *
         * @param response
         * @param list      查询数据集合
         * @param filename  文件名前缀
         * @param title     属性名称
         * @param strTitleE 属性
         * @throws Exception
         */
        public static void export(HttpServletResponse response, List list, String filename, List<String> title, String[] strTitleE) throws Exception {
            int[] widths = {15, 15, 15, 15};
            XSSFWorkbook wb = new XSSFWorkbook();
            // 设置列宽
            XSSFSheet sheet = setSheet(wb, filename, widths);
            //XSSFSheet sheet = wb.createSheet(filename);
            // 设置Excel表格头数据
            setTitleRowData(wb, sheet, title);
            setRowData(wb, sheet, list, strTitleE);
            // 导出Excel(单工作表)
            exportToExcel(response, wb, filename);
        }
    /**
         * 设置列宽 <br />
         *
         * @param workbook
         * @param sheetTitle
         * @param widths
         * @return
         */
        public XSSFSheet setSheet(XSSFWorkbook workbook, String sheetTitle, int[] widths) {
            XSSFSheet sheet = workbook.createSheet(sheetTitle);// 建立新的sheet对象
            for (int i = 0; i < widths.length; i++) {
                sheet.setColumnWidth(i, (int) 256 * widths[i]);
            }
            return sheet;
        }
     /**
         * 设置Excel表格头数据 <br />
         *
         * @param workbook
         * @param sheet
         * @param titles
         * @throws Exception
         */
        public void setTitleRowData(XSSFWorkbook workbook, XSSFSheet sheet, List<String> titles) {
            XSSFRow rowTitle = sheet.createRow(0);// 建立新行
            XSSFCellStyle cellStyle = setCellStyle(workbook);
            for (int i = 0; i < titles.size(); i++) {
                XSSFCell cell = rowTitle.createCell(i);
                // cell.setEncoding(HSSFCell.ENCODING_UTF_16); //设置cell编码解决中文高位字节截断
                cell.setCellValue(titles.get(i));
                cell.setCellStyle(cellStyle);
            }
        }
    /**
         * 为Excel添加行数据 <br />
         *
         * @param workbook
         * @param sheet
         * @param lists
         * @throws Exception
         */
        @SuppressWarnings({"rawtypes", "unchecked"})
        public void setRowData(XSSFWorkbook workbook, XSSFSheet sheet, List lists, String[] valueField) throws Exception {
            if (valueField == null || valueField.length < 1) {
                setRowData(workbook, sheet, lists);
            }
            for (int i = 1; i <= lists.size(); i++) {
                // HSSFRow row = sheet.createRow((short)i);//建立新行
                XSSFRow row = sheet.createRow(i); // 不用short类型,支持大数据量导出
                Object obj = lists.get(i - 1);
                Class clazz = obj.getClass();
                int index = 0;
                for (int j = 0; j < valueField.length; j++) {
                    Method method = clazz.getMethod("get" + valueField[j].substring(0, 1).toUpperCase() + valueField[j].substring(1));
                    Object objValue = method.invoke(lists.get(i - 1));
                    XSSFCell cell = row.createCell(index);
                    if (objValue != null) {
                        cell.setCellValue(objValue.toString());
                    }
                    index++;
                }
            }
        }
    /**
         * 导出Excel(单工作表)
         *
         * @param response
         * @param title
         * @throws Exception
         */
        public static void exportToExcel(HttpServletResponse response, XSSFWorkbook workbook, String title)
                throws Exception {
            try {
                String time = (new SimpleDateFormat("yyyyMMddHHmm")).format(new Date());
                String sFileName = new String((title + "_" + time + ".xls").getBytes("gbk"), "ISO-8859-1");
                response.setHeader("Content-Disposition", "attachment;filename=".concat(sFileName));
                response.setHeader("Connection", "close");
                response.setHeader("Content-Type", "application/vnd.ms-excel");
                workbook.write(response.getOutputStream());
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                workbook.close();
            }
        }

      

    //调用导出的方法
    @RequestMapping("/exportList")
    @ResponseBody
    public void downDsMapPub(HttpServletResponse response){
      //list 表示查询的集合
      //titleList 表示导出的字段的中文名
       //strTitle 表示导出的字段,必须与实体类上的名字相对应
      //fileName 表示导出的文件名 ExcelUtils.export(response,list,fileName,titleList,strTitle); }

      

  • 相关阅读:
    hdoj 1237 模拟
    Codeforces 242E:XOR on Segment(位上的线段树)***
    Tsinsen A1333: 矩阵乘法(整体二分)
    HDU 2830:Matrix Swapping II(思维)
    BZOJ 3110:[Zjoi2013]K大数查询(整体二分)
    POJ 2104:K-th Number(整体二分)
    玲珑OJ 1083:XJT Love Digits(离线处理+哈希)
    玲珑OJ 1082:XJT Loves Boggle(爆搜)
    模板:树状数组(带区间修改和区间更新)
    HDU 5618:Jam's problem again(CDQ分治+树状数组处理三维偏序)
  • 原文地址:https://www.cnblogs.com/bingrong/p/7699854.html
Copyright © 2011-2022 走看看