ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

excel文件导出工具

2022-06-07 16:01:35  阅读:146  来源: 互联网

标签:文件 excel writer 导出 private fileName import data


import cn.hutool.core.util.ObjectUtil;
import cn.hutool.poi.excel.ExcelWriter;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;

/**
 * excel工具
 *
 * @version 1.0
 * @date 2022/4/27 21:45
 * @since : JDK 11
 */
public class ExcelUtil extends cn.hutool.poi.excel.ExcelUtil {

    private static final String XLS_SUFFIX = ".xls";
    private static final String EXCEL_XLS_CONTENT_TYPE = "application/vnd.ms-excel;charset=utf-8";

    private static final String XLSX_SUFFIX = ".xlsx";
    private static final String EXCEL_XLSX_CONTENT_TYPE = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8";


    /**
     * 导出excel文件
     *
     * @param resp 响应对象
     * @param data 文件数据
     * @param isXlsxType excel类型
     * @throws IOException
     */
    public static void exportExcelFile(HttpServletResponse resp, ExcelData data, Boolean isXlsxType) throws IOException {
        ExcelWriter writer;
        StringBuilder fileName = new StringBuilder("attachment;filename=" + URLEncoder.encode(data.getFileName(), StandardCharsets.UTF_8));
        if (isXlsxType) {
            writer = getWriter(isXlsxType);
            fileName = fileName.append(XLSX_SUFFIX);
            resp.setContentType(EXCEL_XLSX_CONTENT_TYPE);
        } else {
            writer = getWriter();
            fileName = fileName.append(XLS_SUFFIX);
            resp.setContentType(EXCEL_XLS_CONTENT_TYPE);
        }
        resp.setHeader("Content-Disposition", fileName.toString());
        writer.renameSheet(data.getSheetName());
        if (ObjectUtil.isNotNull(data.getTitle())) {
            writer.merge(data.getRows().get(0).size() - 1, data.getTitle());
        }
        writer.write(data.getRows(), true);
        writer.flush(resp.getOutputStream());
        writer.close();
    }
}

import lombok.Data;
import lombok.experimental.Accessors;

import java.util.List;
import java.util.Map;

/**
 * excel 数据对象
 *
 * @author JHL
 * @version 1.0
 * @date 2022/4/27 23:03
 * @since : JDK 11
 */

@Data
@Accessors(chain = true)
public class ExcelData {
    private String fileName;
    private String sheetName;
    private String title;
    private List<Map<String, ?>> rows;
}

标签:文件,excel,writer,导出,private,fileName,import,data
来源: https://www.cnblogs.com/hhddd-1024/p/16352147.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有