zoukankan      html  css  js  c++  java
  • java POI 利用隐藏sheet实现导出下拉数据太多为空

    java POI  利用隐藏sheet实现导出下拉数据太多为空:

    1.创建隐藏sheet

           
           // 创建隐藏sheet
           List<String> phaseNameList = getPhaseNames(); if (CollectionUtils.isNotEmpty(phaseNameList)) { wb.createSheet("销售阶段"); wb.setSheetHidden(wb.getSheetIndex(wb.getSheet("销售阶段")), true); Sheet sheet = wb.getSheet("销售阶段"); sheet.createRow(0);//sheet.getLastRowNum无法区分 有一行和没有 所以这里先建一行 String colName = "A"; int colNum = Integer.valueOf(colName.charAt(0)) - 65; Row row; //创建数据行 sheet.setColumnWidth(colNum, 4000); //设置每列的列宽 for (int j = 0; j < phaseNameList.size(); j++) { if (sheet.getLastRowNum() < j) { row = sheet.createRow(j); //创建数据行 } else { row = sheet.getRow(j); } //设置对应单元格的值 row.createCell(colNum).setCellValue(phaseNameList.get(j)); } }
            
     
    2.将隐藏sheet的数据绑定在单元格
                    String colName = "A";
                    List<String> phaseNames = new ArrayList<>(Arrays.asList(getPhaseNames()));
                    int row = CollectionUtils.isEmpty(phaseNames) ? 1 : phaseNames.size();
                    String strFormula = "销售阶段!$" + colName + "$1:$" + colName + "$" + row;
                    XSSFDataValidationConstraint constraint = new XSSFDataValidationConstraint(DataValidationConstraint.ValidationType.LIST,strFormula);
                    // 设置数据有效性加载在哪个单元格上,四个参数分别是:起始行、终止行、起始列、终止列
                    CellRangeAddressList regions = new CellRangeAddressList(0, 65535, columnIndex, columnIndex);
                    // 数据有效性对象
                    DataValidationHelper help = new XSSFDataValidationHelper((XSSFSheet) xssfSheet);
                    DataValidation validation = help.createValidation(constraint, regions);
                    xssfSheet.addValidationData(validation);  
     
    随笔看心情
  • 相关阅读:
    Hadoop一直处于安全模式(hadoop去掉保护模式)
    日考
    MySQL中文编码
    Mussel使用系列(二):开始写我们的第一个Mussel插件项目
    什么是Mussel
    Mussel使用系列(四):从容器中访问Mussel的插件项目
    Mussel使用系列(三):Mussel插件树的构成及初步使用
    Mussel使用系列(五):插件项目之间的调用
    Mussel使用系列(一):Mussel配置文件演示
    C#委托探索之猫和老鼠
  • 原文地址:https://www.cnblogs.com/stromgao/p/14484228.html
Copyright © 2011-2022 走看看