EasyExcel导出Excel时创建下拉框

2 篇文章 0 订阅
@Data
public class SpinnerWriteHandler implements SheetWriteHandler {
	//传入下拉框数组
    private String[] pidName;
    //传入的下拉框数组
    private String[] name;

    public SpinnerWriteHandler() {
    }

    public SpinnerWriteHandler(String[] pidName, String[] name) {
        this.pidName = pidName;
        this.name = name;
    }

    @Override
    public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
    }
    
    @Override
    public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
    	//设置下拉框数据
        Map<Integer, String[]> map = new HashMap<>();
        map.put(1, this.pidName);
        map.put(2, this.name);
        
        Sheet sheet = writeSheetHolder.getSheet();
        // 开始设置下拉框
        DataValidationHelper helper = sheet.getDataValidationHelper();
        for (Map.Entry<Integer, String[]> entry : map.entrySet()) {
            //起始行、终止行、起始列、终止列 
            CellRangeAddressList addressList = new CellRangeAddressList(1, 3000, entry.getKey(), entry.getKey());
            //设置下拉框数据
            DataValidationConstraint constraint = helper.createExplicitListConstraint(entry.getValue());
            DataValidation dataValidation = helper.createValidation(constraint, addressList);
            //处理Excel兼容性问题
            if (dataValidation instanceof XSSFDataValidation){
                dataValidation.setSuppressDropDownArrow(true);
                dataValidation.setShowErrorBox(true);
            } else {
                dataValidation.setSuppressDropDownArrow(false);
            }
            sheet.addValidationData(dataValidation);
        }
    }
}
    public void exportTemplate(HttpServletResponse response) throws Exception {
    	//导出的数据(根据需要自行修改)
        List<GamsApplicationAssetcardDTO> list = new ArrayList<>();
        //下拉框数据(根据需要自行修改)
        String[] pidNames = {"小学", "初中", "高中", "大学"};
        //下拉框数据(根据需要自行修改)
        String[] names = {"语文", "数学", "英语"};

		//把导出数据的GamsApplicationAssetcardDTO实体类转换成导出的GamsApplicationAssetcardExcel类
        List targetList = new ArrayList<>(list.size());
        for (Object source : list) {
            Object target = GamsApplicationAssetcardExcel.class.newInstance();
            BeanUtils.copyProperties(source, target);
            targetList.add(target);
        }

        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("UTF-8");
        String fileName = URLEncoder.encode("测试", "UTF-8");
        response.setHeader("Content-disposition", "attachment;filename=" +  fileName + ".xlsx");
        EasyExcel
                .write(response.getOutputStream(), GamsApplicationAssetcardExcel.class)
                .registerWriteHandler(new SpinnerWriteHandler(pidNames, names)) //设置下拉框数组
                .sheet("测试")
                .doWrite(list); //添加数据
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值