POI导出Excel

POI是一款很好用的api,下面这个方法是供前台页面调用,供用户选择存储位置的:

    /**
 *
 * <p>
 * Description: excel导出
 * </p>
 *
 * @param request 请求
 * @param response 响应
 * @param fileName 文件名
 * @param columnTitles 列头名
 * @param columnNames 列英文名
 * @param columnFormats 列类型
 * @param sheetName 工作簿
 * @param listData 数据集合
 * @throws IOException 输入异常
 */
@SuppressWarnings({ "deprecation" , "unused" })
public static void export(HttpServletRequest request, HttpServletResponse response, String fileName,
        String[] columnTitles, String[] columnNames, String[] columnFormats, String sheetName,
        List<Map<String, Object>> listData) throws IOException {
    //创建一个新的Excel 
    HSSFWorkbook workBook;
    workBook = new HSSFWorkbook();

    // 生成一个表头样式
    HSSFCellStyle styleTitle;
    styleTitle = workBook.createCellStyle();
    styleTitle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
    styleTitle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
    styleTitle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderRight(HSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderTop(HSSFCellStyle.BORDER_THIN);
    styleTitle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
    styleTitle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
    styleTitle.setAlignment(HSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleTitle.setWrapText( true);
    /*
     * HSSFFont font; font = workBook.createFont();
     * font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //字体加粗
     * font.setFontHeight((short) WZDX); // 设置字体大小 font.setFontName("宋体");
     * // 设置单元格字体 styleTitle.setFont(font);
     */

    //创建列的样式
    HSSFCellStyle styleCell;
    styleCell = workBook.createCellStyle();
    styleCell.setBorderBottom(HSSFCellStyle.BORDER_THIN);
    styleCell.setBorderLeft(HSSFCellStyle.BORDER_THIN);
    styleCell.setBorderRight(HSSFCellStyle.BORDER_THIN);
    styleCell.setBorderTop(HSSFCellStyle.BORDER_THIN);
    styleCell.setAlignment(HSSFCellStyle.ALIGN_CENTER);
    styleCell.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
    styleCell.setAlignment(HSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCell.setWrapText( true);
   
    //创建列的样式
    HSSFCellStyle styleCellNumber;
    styleCellNumber = workBook.createCellStyle();
    styleCellNumber.setBorderBottom(HSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderLeft(HSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderRight(HSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderTop(HSSFCellStyle.BORDER_THIN);
    styleCellNumber.setAlignment(HSSFCellStyle.ALIGN_CENTER);
    styleCellNumber.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
    styleCellNumber.setAlignment(HSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCellNumber.setDataFormat(HSSFDataFormat.getBuiltinFormat( "0"));
   
    //创建列的样式
    HSSFCellStyle styleCellDouble;
    styleCellDouble = workBook.createCellStyle();
    styleCellDouble.setBorderBottom(HSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderLeft(HSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderRight(HSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderTop(HSSFCellStyle.BORDER_THIN);
    styleCellDouble.setAlignment(HSSFCellStyle.ALIGN_CENTER);
    styleCellDouble.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
    styleCellDouble.setAlignment(HSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCellDouble.setWrapText( true);
    styleCellDouble.setDataFormat(HSSFDataFormat.getBuiltinFormat( "0.00"));
    //创建sheet页 
    HSSFSheet sheet;
    sheet = workBook.createSheet();
    //每一列的format如果没有被设置,默认全部为string
    String[] columnFormatArr = null;
    if (columnFormats == null) {
        columnFormatArr = new String[columnNames.length ];
        for (int i = 0; i < columnFormatArr.length; i++) {
            columnFormatArr[i] = COLUMN_FORMAT_STRING ;
        }
        //否则按照配置的读取
    } else {
        columnFormatArr = columnFormats;
    }
    //sheet页名称   如果没有进行传送 则为默认的工作簿名称
    if (sheetName != null && sheetName.length() > 0) {
        workBook.setSheetName(0, sheetName);
    } else {
        workBook.setSheetName(0, SHEET_NAME);
    }
    //给表的列头赋值
    HSSFHeader header;
    header = sheet.getHeader();
    HSSFRow row; //第一行
    row = sheet.createRow(0); //设置第一行为Header
    // 设置表格默认列宽度为13个字节
    sheet. setDefaultColumnWidth((short) THIRTEENTH);
    sheet.setDefaultRowHeightInPoints(( short) TWENTY);
    //动态添加列头
    for (int i = 0; i < columnTitles.length; i++) {
        HSSFCell cell = null;
        cell = row. createCell(Short.valueOf(i + ""));
        cell.setCellValue(columnTitles[i]);
        cell.setCellStyle(styleTitle);
    }
    if (null != listData) { //数据为空是 则不用填充数据
        // 填充excel数据
        for (int i = 0; i < listData.size(); i++) {
            final int START_ROW = 1;
            HSSFRow rows;
            rows = sheet.createRow(START_ROW + i);
            for (int j = 0; j < columnNames.length; j++) {
                HSSFCell cells = null;
                cells = rows.createCell(Short.valueOf(j + "" ));
                Object columnObject;
                columnObject = listData.get(i).get(columnNames[j]);
                String columnValue = null;
                if (columnObject == null) {
                    columnValue = "";
                } else if (COLUMN_FORMAT_STRING .equals(columnFormatArr[j].toUpperCase())) {
                    columnValue = columnObject.toString();
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DICT )) {
                    /*
                     * String rootKey; 此处是字典 设置 rootKey =
                     * columnFormatArr[j].substring
                     * (COLUMN_FORMAT_DICT.length()); columnValue =
                     * columnObject.toString(); columnValue =
                     * dictService.findDictValueByDictKey(rootKey,
                     * columnValue);
                     */
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DATE )) {

                    /*
                     * CellStyle cellStyle = workBook.createCellStyle();
                     * DataFormat format= workBook.createDataFormat();
                     * cellStyle
                     * .setDataFormat(format.getFormat("yyyy-MM- dd"));
                     * cell.setCellStyle(cellStyle);
                     */
                    String dateFormat;
                    dateFormat = columnFormatArr[j].substring(COLUMN_FORMAT_DATE .length());
                    SimpleDateFormat sdf;
                    sdf = new SimpleDateFormat(dateFormat);
                    columnValue = sdf.format(columnObject);
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_NUMBER )) {
                    cells.setCellType(Cell.CELL_TYPE_NUMERIC );
                    cells.setCellValue(Integer.parseInt(columnObject.toString()));
                    //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                    cells.setCellStyle(styleCellNumber);
                    continue;
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DOUBLE )) {
                    cells.setCellType(Cell.CELL_TYPE_NUMERIC );
                    cells.setCellValue(Double.parseDouble(columnObject.toString()));
                    //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                    cells.setCellStyle(styleCellDouble);
                    continue;
                }
               
                cells.setCellValue(columnValue);
                //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                cells.setCellStyle(styleCell);
            }
        }
    }
    response.setContentType("application/vnd.ms-excel" );
    //response.setContentType(contentType);
    response.setHeader( CONTENT_DISPOSITION, ATTACHMENT
            + new String((fileName).getBytes(GBK ), "iso8859-1") + ".xls");
    response.setCharacterEncoding( ISO8859);
    OutputStream ouputStream;
    ouputStream = response.getOutputStream();
    workBook.write(ouputStream);
    ouputStream.flush();
    ouputStream.close();
}

对此方法稍作修改,可以改成后台方法生成excel到指定的路径下面:

/**
 *
 * <p>
 * Description: excel导出 供后台任务生成excel 调用
 * </p>
 *
 * @param fileName 文件名
 * @param columnTitles 列头名
 * @param columnNames 列英文名
 * @param columnFormats 列类型
 * @param sheetName 工作簿
 * @param listData 数据集合
 * @throws IOException 输入异常
 */
@SuppressWarnings({ "unused" })
public static void exportToSpecifiedPath(String fileName,
        String[] columnTitles, String[] columnNames, String[] columnFormats, String sheetName,
        List<Map<String, Object>> listData) throws IOException {
    //创建一个新的Excel 
    XSSFWorkbook workBook;
    workBook = new XSSFWorkbook();

    XSSFFont font;
    font = workBook.createFont();
    font.setFontHeightInPoints(( short) TEN );
    // 生成一个表头样式
    XSSFCellStyle styleTitle;
    styleTitle = workBook.createCellStyle();
    styleTitle.setFillForegroundColor( new XSSFColor(new Color(0, BLUE_TWO, BLUE_THREE)));
    styleTitle.setFillPattern(XSSFCellStyle.SOLID_FOREGROUND);
    styleTitle.setBorderBottom(XSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderLeft(XSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderRight(XSSFCellStyle.BORDER_THIN);
    styleTitle.setBorderTop(XSSFCellStyle.BORDER_THIN);
    styleTitle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
    styleTitle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
    styleTitle.setAlignment(XSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleTitle.setWrapText( true);
    /*
     * HSSFFont font; font = workBook.createFont();
     * font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //字体加粗
     * font.setFontHeight((short) WZDX); // 设置字体大小 font.setFontName("宋体");
     * // 设置单元格字体 styleTitle.setFont(font);
     */
    styleTitle.setFont(font);
    //创建列的样式
    XSSFCellStyle styleCell;
    styleCell = workBook.createCellStyle();
    styleCell.setBorderBottom(XSSFCellStyle.BORDER_THIN);
    styleCell.setBorderLeft(XSSFCellStyle.BORDER_THIN);
    styleCell.setBorderRight(XSSFCellStyle.BORDER_THIN);
    styleCell.setBorderTop(XSSFCellStyle.BORDER_THIN);
    styleCell.setAlignment(XSSFCellStyle.ALIGN_CENTER);
    styleCell.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
    styleCell.setAlignment(XSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCell.setWrapText( true);
    styleCell.setFont(font);
   
    //创建列的样式
    XSSFCellStyle styleCellNumber;
    styleCellNumber = workBook.createCellStyle();
    styleCellNumber.setBorderBottom(XSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderLeft(XSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderRight(XSSFCellStyle.BORDER_THIN);
    styleCellNumber.setBorderTop(XSSFCellStyle.BORDER_THIN);
    styleCellNumber.setAlignment(XSSFCellStyle.ALIGN_CENTER);
    styleCellNumber.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
    styleCellNumber.setAlignment(XSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCellNumber.setDataFormat(workBook.createDataFormat().getFormat("0"));
    styleCellNumber.setFont(font);
   
    //创建列的样式
    XSSFCellStyle styleCellDouble;
    styleCellDouble = workBook.createCellStyle();
    styleCellDouble.setBorderBottom(XSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderLeft(XSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderRight(XSSFCellStyle.BORDER_THIN);
    styleCellDouble.setBorderTop(XSSFCellStyle.BORDER_THIN);
    styleCellDouble.setAlignment(XSSFCellStyle.ALIGN_CENTER);
    styleCellDouble.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
    styleCellDouble.setAlignment(XSSFCellStyle.ALIGN_CENTER); //水平布局:居中
    styleCellDouble.setWrapText( true);
    styleCellDouble.setDataFormat(workBook.createDataFormat().getFormat("0.00"));
    styleCellDouble.setFont(font);
   
    //创建sheet页 
    XSSFSheet sheet;
    sheet = workBook.createSheet();
    //每一列的format如果没有被设置,默认全部为string
    String[] columnFormatArr = null;
    if (columnFormats == null) {
        columnFormatArr = new String[columnNames.length ];
        for (int i = 0; i < columnFormatArr.length; i++) {
            columnFormatArr[i] = COLUMN_FORMAT_STRING ;
        }
        //否则按照配置的读取
    } else {
        columnFormatArr = columnFormats;
    }
    //sheet页名称   如果没有进行传送 则为默认的工作簿名称
    if (sheetName != null && sheetName.length() > 0) {
        workBook.setSheetName(0, sheetName);
    } else {
        workBook.setSheetName(0, SHEET_NAME);
    }
    //给表的列头赋值
    Header header;
    header = sheet.getHeader();
    XSSFRow row; //第一行
    row = sheet.createRow(0); //设置第一行为Header
    // 设置表格默认列宽度为13个字节
    sheet.setDefaultColumnWidth(( short) THIRTEENTH);
    sheet.setDefaultRowHeightInPoints(( short) TWENTY);
    //动态添加列头
    for (int i = 0; i < columnTitles.length; i++) {
        XSSFCell cell = null;
        cell = row.createCell(Short. valueOf(i + ""));
        cell.setCellValue(columnTitles[i]);
        cell.setCellStyle(styleTitle);
    }
    if (null != listData) { //数据为空是 则不用填充数据
        // 填充excel数据
        for (int i = 0; i < listData.size(); i++) {
            final int START_ROW = 1;
            XSSFRow rows;
            rows = sheet.createRow(START_ROW + i);
            for (int j = 0; j < columnNames.length; j++) {
                XSSFCell cells = null;
                cells = rows.createCell(Short.valueOf(j + ""));
                Object columnObject;
                columnObject = listData.get(i).get(columnNames[j]);
                String columnValue = null;
                if (columnObject == null) {
                    columnValue = "";
                } else if (COLUMN_FORMAT_STRING .equals(columnFormatArr[j].toUpperCase())) {
                    columnValue = columnObject.toString();
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DICT )) {
                    /*
                     * String rootKey; 此处是字典 设置 rootKey =
                     * columnFormatArr[j].substring
                     * (COLUMN_FORMAT_DICT.length()); columnValue =
                     * columnObject.toString(); columnValue =
                     * dictService.findDictValueByDictKey(rootKey,
                     * columnValue);
                     */
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DATE )) {

                    /*
                     * CellStyle cellStyle = workBook.createCellStyle();
                     * DataFormat format= workBook.createDataFormat();
                     * cellStyle
                     * .setDataFormat(format.getFormat("yyyy-MM- dd"));
                     * cell.setCellStyle(cellStyle);
                     */
                    String dateFormat;
                    dateFormat = columnFormatArr[j].substring(COLUMN_FORMAT_DATE .length());
                    SimpleDateFormat sdf;
                    sdf = new SimpleDateFormat(dateFormat);
                    columnValue = sdf.format(columnObject);
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_NUMBER )) {
                    cells.setCellType(Cell.CELL_TYPE_NUMERIC );
                    cells.setCellValue(Integer.parseInt(columnObject.toString()));
                    //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                    cells.setCellStyle(styleCellNumber);
                    continue;
                } else if (columnFormatArr[j].startsWith(COLUMN_FORMAT_DOUBLE )) {
                    cells.setCellType(Cell.CELL_TYPE_NUMERIC );
                    cells.setCellValue(Double.parseDouble(columnObject.toString()));
                    //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                    cells.setCellStyle(styleCellDouble);
                    continue;
                }
               
                cells.setCellValue(columnValue);
                //sheet.autoSizeColumn((short)columnValue.getBytes().length);
                cells.setCellStyle(styleCell);
            }
        }
    }
    File file;
    file = new File(fileName);
    FileOutputStream ouputStream;
    ouputStream = new FileOutputStream(file);
    workBook.write(ouputStream);
    ouputStream.flush();
    ouputStream.close();
}

后面一个方法生成的是xlsx格式,03版本的工作簿支持的条数较少,如果数量比较大,可以选择导出xlsx格式的,主要就是导入的jar不同。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

推荐阅读

  • 远程办公经验为0,如何将日常工作平滑过度到线上?

    我是一名创业者,我的公司(深圳市友浩达科技有限公司)在2018年8月8日开始运营,现在还属于微型公司。这个春节假期,我一直十分关注疫情动向,也非常关心其对公司带来的影响。

    TVP官方团队
    TAPD 敏捷项目管理腾讯乐享企业邮箱企业编程算法
  • 数据中台,概念炒作还是另有奇效? | TVP思享

    作者简介:史凯,花名凯哥,腾讯云最具价值专家TVP,ThoughtWorks数据智能业务总经理。投身于企业数字化转型工作近20年。2000年初,在IBM 研发企业级中间件,接着加入埃森哲,为大型企业提供信息化架构规划,设计,ERP,云平台,数据仓库构建等技术咨询实施服务,随后在EMC负责企业应用转型业务,为企业提供云迁移,应用现代化服务。现在专注于企业智能化转型领域,是数据驱动的数字化转型的行业布道者,数据中台的推广者,精益数据创新体系的创始人,2019年荣获全球Data IQ 100人的数据赋能者称号,创业邦卓越生态聚合赋能官TOP 5。2019年度数字化转型专家奖。打造了行业第一个数据创新的数字化转型卡牌和工作坊。创建了精益数据创新方法论体系构建数据驱动的智能企业,并在多个企业验证成功,正在向国内外推广。

    TVP官方团队
    大数据数据分析企业
  • 扩展 Kubernetes 之 CRI

    使用 cri-containerd 的调用流程更为简洁, 省去了上面的调用流程的 1,2 两步

    王磊-AI基础
    Kubernetes
  • 扩展 Kubernetes 之 Kubectl Plugin

    kubectl 功能非常强大, 常见的命令使用方式可以参考 kubectl --help,或者这篇文章

    王磊-AI基础
    Kubernetes
  • 多种登录方式定量性能测试方案

    最近接到到一个测试任务,某服务提供了两种登录方式:1、账号密码登录;2、手机号+验证码登录。要对这两种登录按照一定的比例进行压测。

    八音弦
    测试服务 WeTest
  • 线程安全类在性能测试中应用

    首先验证接口参数签名是否正确,然后加锁去判断订单信息和状态,处理用户增添VIP时间事务,成功之后释放锁。锁是针对用户和订单的分布式锁,使用方案是用的redis。

    八音弦
    安全编程算法
  • 使用CDN(jsdelivr) 优化博客访问速度

    PS: 此篇文章适用于 使用 Github pages 或者 coding pages 的朋友,其他博客也类似.

    IFONLY@CUIT
    CDNGitGitHub开源
  • 扩展 Kubernetes 之 CNI

    Network Configuration 是 CNI 输入参数中最重要当部分, 可以存储在磁盘上

    王磊-AI基础
    Kubernetes
  • 聚焦【技术应变力】云加社区沙龙online重磅上线!

    云加社区结合特殊时期热点,挑选备受关注的音视频流量暴增、线下业务快速转线上、紧急上线防疫IoT应用等话题,邀请众多业界专家,为大家提供连续十一天的干货分享。从视野、预判、应对等多角度,帮助大家全面提升「技术应变力」!

    腾小云
  • 京东购物小程序购物车性能优化实践

    它是小程序开发工具内置的一个可视化监控工具,能够在 OS 级别上实时记录系统资源的使用情况。

    WecTeam
    渲染JavaScripthttps网络安全缓存

扫码关注云+社区

领取腾讯云代金券