ExcelUtils导出工具类

ExcelUtils 导出工具类

package com.ruqi.travel.user.utils;

import com.alibaba.excel.EasyExcelFactory;
import com.alibaba.excel.write.builder.ExcelWriterBuilder;
import com.alibaba.excel.write.metadata.style.WriteCellStyle;
import com.alibaba.excel.write.style.HorizontalCellStyleStrategy;
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
import org.apache.poi.ss.usermodel.HorizontalAlignment;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Collection;
import java.util.List;

/**
 * @DESCRIPTION: excel导出
 * @author:zhaiqw
 * @date 2019/11/11
 */
public class ExcelUtils {

    public static OutputStream getOutputStream(HttpServletResponse response) throws IOException {
        String fileName = DateTimeFormatter.ofPattern("yyyyMMddHHmmss").format(LocalDateTime.now());
        //response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        response.setHeader("Content-Disposition", "attachment; filename=" + fileName + ".xlsx");
        response.setHeader("Pragma", "public");
        response.setHeader("Cache-Control", "no-store");
        response.setHeader("Cache-Control", "max-age=0");
        return response.getOutputStream();
    }

    /**
     * 重构excel导出自定义文件名。
     *
     * @param response
     * @param fileName
     * @return
     * @throws IOException
     */
    public static OutputStream getOutputStream(HttpServletResponse response, String fileName) throws IOException {
        String encode = URLEncoder.encode(fileName, "UTF-8");
        String contentDisposition = "attachment;filename=" + encode + ".xlsx";
        response.setCharacterEncoding("utf-8");
        response.setHeader("Content-Disposition", contentDisposition);
        response.setHeader("Pragma", "public");
        response.setHeader("Cache-Control", "no-store");
        response.setHeader("Cache-Control", "max-age=0");
        return response.getOutputStream();
    }

    /**
     * excel导出
     *
     * @param response
     * @param includeColumns
     * @param dataList
     * @param clazz
     * @param <T>
     */
    public static <T> void excelSimpleWrite(HttpServletResponse response, Collection<String> includeColumns,
                                            List<T> dataList, Class<T> clazz) throws IOException {
        // 设置头部及内容样式
        HorizontalCellStyleStrategy horizontalCellStyleStrategy = initStyleStrategy();

        synchronized (clazz) {
            ExcelWriterBuilder writer = EasyExcelFactory.write(getOutputStream(response), clazz);
            writer.registerWriteHandler(horizontalCellStyleStrategy)
                    .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
                    .includeColumnFiledNames(includeColumns)
                    .sheet("Sheet1")
                    .doWrite(dataList);
        }
    }

    /**
     * 重构excel导出工具类,可以自定义文件名字和页名
     *
     * @param fileName
     * @param sheetName
     * @param response
     * @param excludeColumns
     * @param dataList
     * @param clazz
     * @param <T>
     * @throws IOException
     */
    public static <T> void excelSimpleWrite(String fileName, String sheetName, HttpServletResponse response, Collection<String> excludeColumns, List<T> dataList, Class<T> clazz) throws IOException {
        // 设置头部及内容样式
        HorizontalCellStyleStrategy horizontalCellStyleStrategy = initStyleStrategy();

        synchronized (clazz) {
            ExcelWriterBuilder writer = EasyExcelFactory.write(getOutputStream(response, fileName), clazz);
            writer.registerWriteHandler(horizontalCellStyleStrategy)
                    .registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
                    .excludeColumnFiledNames(excludeColumns)
                    .sheet(sheetName)
                    .doWrite(dataList);
        }
    }

    /**
     * 设置头部及内容样式策略
     *
     * @return
     */
    private static HorizontalCellStyleStrategy initStyleStrategy() {
        WriteCellStyle contentCellStyle = new WriteCellStyle();
        contentCellStyle.setWrapped(true);
        contentCellStyle.setHorizontalAlignment(HorizontalAlignment.CENTER);
        return new HorizontalCellStyleStrategy(new WriteCellStyle(), contentCellStyle);
    }



}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中可以使用Apache POI库来操作Excel文件。其中,ExcelUtils是一个封装了POI库的工具类,可以方便地实现Excel的导入和导出。 1. 导入Excel ExcelUtils中提供了一个importExcel方法,可以将Excel文件中的数据导入到Java对象中。该方法的参数包括Excel文件的路径、Java对象的类型和需要导入的Excel表格的名称。例如: ```java List<User> userList = ExcelUtils.importExcel("user.xlsx", User.class, "Sheet1"); ``` 其中,"user.xlsx"是Excel文件的路径,User.class是需要导入的Java对象的类型,"Sheet1"是需要导入的Excel表格的名称。 2. 导出Excel ExcelUtils中提供了一个exportExcel方法,可以将Java对象中的数据导出Excel文件中。该方法的参数包括Excel文件的路径、Excel表格的名称、Java对象列表和Excel表头信息。例如: ```java List<User> userList = new ArrayList<>(); // 添加用户数据到userList中 String[] headers = {"ID", "姓名", "年龄", "性别"}; ExcelUtils.exportExcel("user.xlsx", "Sheet1", userList, headers); ``` 其中,"user.xlsx"是Excel文件的路径,"Sheet1"是需要导出Excel表格的名称,userList是Java对象列表,headers是Excel表头信息。 需要注意的是,导入和导出Excel时,需要在项目中引入POI库的依赖。例如,在Maven项目中,可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.17</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.17</version> </dependency> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值