Easyexcel导出带下拉框选项excel模板

该博客介绍了如何使用EasyExcel库在导出Excel模板时动态生成表头字段和sheet页的下拉框内容。通过创建一个固定的字典sheet页存储下拉框选项,并利用公式关联,解决了选项过多可能导致内容不显示的问题。示例代码展示了如何设置下拉框以及实现动态生成的逻辑。
摘要由CSDN通过智能技术生成

需求:导出的excel模板,表头字段动态生成、sheet页下拉框内容动态生成

解决思路:为了避免excel下拉框选项过多会导致内容不显示,将下拉框的内容都存储在另一个新建的固定的sheet页,再通过引用公式关联单元格的下拉框内容。

maven依赖

<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>easyexcel</artifactId>
     <version>2.2.7</version>
</dependency>

导出代码

@RequestMapping("/download")
    public void download(HttpServletResponse response) throws IOException {
        String fileName = "test";
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
        String fileNameEncode = URLEncoder.encode(fileName, "UTF-8");
        response.setHeader("Content-disposition", "attachment;filename=" + fileNameEncode + ExcelTypeEnum.XLS.getValue());
        // 模拟下拉框内容
        Map<Integer, List<String>> selectMap = new HashMap<>();
        List<String> sexList = new ArrayList<>();
        sexList.add("男");
        sexList.add("女");
        selectMap.put(1, sexList);
        List<String> typeList = new ArrayList<>();
        typeList.add("股票");
        typeList.add("基金");
        typeList.add("债券");
        selectMap.put(2, typeList);
        //模拟表头
        List<List<String>> list = new ArrayList<>();
        List<String> field1 = new ArrayList<>();
        List<String> field2 = new ArrayList<>();
        List<String> field3 = new ArrayList<>();
        field1.add("编号");
        field2.add("性别");
        field3.add("类型");
        list.add(field1);
        list.add(field2);
        list.add(field3);
        EasyExcelFactory.write(response.getOutputStream())
                .registerWriteHandler(new SelectSheetWriteHandler(selectMap))
                .excelType(ExcelTypeEnum.XLS)
                .head(list)
                .sheet("测试sheet")
                .doWrite(new ArrayList());
    }

下拉框设置代码

package com.test.excel;

import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import org.apache.poi.hssf.usermodel.HSSFDataValidation;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddressList;

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

/**
 * @author 
 * @date 2021/12/20
 */
public class SelectSheetWriteHandler implements SheetWriteHandler {
    private Map<Integer, List<String>> selectMap;

    private char[] alphabet = new char[]{'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L',
            'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};

    public SelectSheetWriteHandler(Map<Integer, List<String>> selectMap) {
        this.selectMap = selectMap;
    }

    @Override
    public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
    }

    @Override
    public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
        if (selectMap == null || selectMap.size() == 0) {
            return;
        }
        // 需要设置下拉框的sheet页
        Sheet curSheet = writeSheetHolder.getSheet();
        DataValidationHelper helper = curSheet.getDataValidationHelper();
        String dictSheetName = "字典sheet";
        Workbook workbook = writeWorkbookHolder.getWorkbook();
        // 数据字典的sheet页
        Sheet dictSheet = workbook.createSheet(dictSheetName);
        for (Map.Entry<Integer, List<String>> entry : selectMap.entrySet()) {
            // 设置下拉单元格的首行、末行、首列、末列
            CellRangeAddressList rangeAddressList = new CellRangeAddressList(1, 65533, entry.getKey(), entry.getKey());
            int rowLen = entry.getValue().size();
            // 设置字典sheet页的值 每一列一个字典项
            for (int i = 0; i < rowLen; i++) {
                Row row = dictSheet.getRow(i);
                if (row == null) {
                    row = dictSheet.createRow(i);
                }
                row.createCell(entry.getKey()).setCellValue(entry.getValue().get(i));
            }
            String excelColumn = getExcelColumn(entry.getKey());
            // 下拉框数据来源 eg:字典sheet!$B1:$B2
            String refers = dictSheetName + "!$" + excelColumn + "$1:$" + excelColumn + "$" + rowLen;
            // 创建可被其他单元格引用的名称
            Name name = workbook.createName();
            // 设置名称的名字
            name.setNameName("dict" + entry.getKey());
            // 设置公式
            name.setRefersToFormula(refers);
            // 设置引用约束
            DataValidationConstraint constraint = helper.createFormulaListConstraint("dict" + entry.getKey());
            // 设置约束
            DataValidation validation = helper.createValidation(constraint, rangeAddressList);
            if (validation instanceof HSSFDataValidation) {
                validation.setSuppressDropDownArrow(false);
            } else {
                validation.setSuppressDropDownArrow(true);
                validation.setShowErrorBox(true);
            }
            // 阻止输入非下拉框的值
            validation.setErrorStyle(DataValidation.ErrorStyle.STOP);
            validation.createErrorBox("提示", "此值与单元格定义格式不一致!");
            // 添加下拉框约束
            writeSheetHolder.getSheet().addValidationData(validation);
        }
    }

    /**
     * 将数字列转化成为字母列
     *
     * @param num
     * @return
     */
    private String getExcelColumn(int num) {
        String column = "";
        int len = alphabet.length - 1;
        int first = num / len;
        int second = num % len;
        if (num <= len) {
            column = alphabet[num] + "";
        } else {
            column = alphabet[first - 1] + "";
            if (second == 0) {
                column = column + alphabet[len] + "";
            } else {
                column = column + alphabet[second - 1] + "";
            }
        }
        return column;
    }
}

导出excel模板效果如下:

 

 

  • 8
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要在 EasyExcel 中设置下拉框多选,需要进行以下步骤: 1. 定义下拉框的列表数据,可以使用 List<String> 或者 String[] 等类型存储下拉框选项。 2. 创建一个 CellRangeAddressList 对象,用于指定下拉框的范围,可以使用 setFirstRow、setLastRow、setFirstCol、setLastCol 方法分别设置下拉框的起始行、结束行、起始列、结束列。 3. 创建一个 DataValidationHelper 对象,用于创建数据验证规则,在 DataValidationHelper 对象上调用 createValidation 方法,设置下拉框的数据来源、校验规则等。 4. 将创建好的数据验证规则应用到 Excel 单元格中,可以使用 Sheet 对象的 addValidationData 方法将数据验证规则应用到指定的单元格范围。 下面是一个示例代码: ``` List<String> options = Arrays.asList("选项1", "选项2", "选项3"); CellRangeAddressList rangeList = new CellRangeAddressList(0, 10, 0, 0); DataValidationHelper helper = sheet.getDataValidationHelper(); DataValidationConstraint constraint = helper.createExplicitListConstraint(options.toArray(new String[options.size()])); DataValidation validation = helper.createValidation(constraint, rangeList); validation.setShowErrorBox(true); sheet.addValidationData(validation); ``` 上述代码中,options 变量存储了下拉框选项,rangeList 变量指定了下拉框的范围,helper 变量创建了 DataValidationHelper 对象,constraint 变量创建了数据验证规则,validation 变量将数据验证规则应用到了指定的单元格范围。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值