EasyExcel 设置下拉不显示/下拉值超过255,解决方案!


import java.util.Map;

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddressList;

import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;

/**
 * @author pzz
 * @create 2021/9/30
 * @description 下拉自定义拦截器处理
 */
public class DropDownSetFieldCellWriteHandler implements SheetWriteHandler {

    
    private Map<Integer, String[]> map = null;

    public DropDownSetFieldCellWriteHandler(Map<Integer, String[]> map) {
        this.map = map;
    }

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

    @Override
    public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
        //获取一个workbook
        Sheet sheet = writeSheetHolder.getSheet();
        //设置下拉框
        DataValidationHelper helper = sheet.getDataValidationHelper();
        //定义sheet的名称
        String hiddenName = "hidden";
        //1.创建一个隐藏的sheet 名称为 hidden
        Workbook workbook = writeWorkbookHolder.getWorkbook();
        Sheet hidden = workbook.createSheet(hiddenName);
        Name category1Name = workbook.createName();
        category1Name.setNameName(hiddenName);
        for (Map.Entry<Integer, String[]> entry : map.entrySet()) {
            //下拉框的起始行,结束行,起始列,结束列
            CellRangeAddressList addressList = new CellRangeAddressList(1, 2000, entry.getKey(), entry.getKey());
            //获取excel列名
            String excelLine = getExcelLine(entry.getKey());
            //2.循环赋值
            String[] values = entry.getValue();
            for (int i = 0, length = values.length; i < length; i++) {
                // 3:表示你开始的行数  3表示 你开始的列数
                Row row = hidden.getRow(i);
                if (row == null) {
                    row = hidden.createRow(i);
                }
                row.createCell(entry.getKey()).setCellValue(values[i]);
            }
            //4.  =hidden!$H:$1:$H$50  sheet为hidden的 H1列开始H50行数据获取下拉数组
            String refers = "="+hiddenName + "!$"+excelLine+
                    "$1:$"+excelLine +"$"+ (values.length);
            //5 将刚才设置的sheet引用到你的下拉列表中
            DataValidationConstraint constraint = helper.createFormulaListConstraint(refers);
            DataValidation dataValidation = helper.createValidation(constraint, addressList);
            writeSheetHolder.getSheet().addValidationData(dataValidation);
        }
        //设置列为隐藏
        int hiddenIndex = workbook.getSheetIndex("hidden");
        if (!workbook.isSheetHidden(hiddenIndex)) {
            workbook.setSheetHidden(hiddenIndex, true);
        }

    }

    /**
     * @Description 返回excel列标A-Z-AA-ZZ
     * @param num 列数
     * @return java.lang.String
     */
    public static String getExcelLine(int num) {
        String line = "";
        int first = num/26;
        int second = num % 26;
        if (first>0) {
            line = (char)('A'+first-1)+"";
        }
        line += (char)('A'+second)+"";
        return line;
    }
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,可以看出在使用EasyExcel进行导出时,可以通过设置下拉选项来实现。在代码实现中,可以使用`@ExcelSelector`注解来设置下拉选项的。在导出对应的类中,可以使用`@ExcelSelector`注解来指定下拉选项的。例如,在`CameraExportExcel`类中,通过`@ExcelSelector(fixedSelector = {"是", "否"})`来设置"是否配有IM采集模块"这一列的下拉选项为"是"和"否"。\[1\]\[3\] 如果在使用EasyExcel导出时下拉选项无法打开,可能是由于以下几个原因: 1. 未正确引入EasyExcel的依赖。请确保在项目的pom.xml文件中正确添加了EasyExcel的依赖项,如引用\[2\]所示。 2. 未正确设置下拉选项的。请检查代码中`@ExcelSelector`注解的使用是否正确,并确保下拉选项的已正确设置。 3. 导出的数据列表为空。如果导出的数据列表为空,下拉选项可能无法正常显示。请确保导出的数据列表中有数据。 如果以上方法都没有解决问题,建议检查EasyExcel的版本是否与项目的其他依赖项冲突,并尝试更新EasyExcel的版本。另外,也可以查阅EasyExcel的官方文档或寻求相关技术支持来解决问题。 #### 引用[.reference_title] - *1* [基于注解和EasyExcel指定单元格下拉选内容](https://blog.csdn.net/qq_44981526/article/details/128537172)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [easyexcel导出使用注解设置下拉选数据](https://blog.csdn.net/weixin_41481806/article/details/126978596)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值