读到这篇文章,请停下您Ctrl+c,Ctrl+v的脚步。因为这并不是真正的删除数据有效性,而是通过一种方式实现多次为某列设置数据有效性。我是真的百度没查到,Google没查到,官网也没找到关于使用POI删除数据有效性的方法。这里用到的思路是准备一个并没有设置过数据有效性的原始模板,每次修改数据有效性都复制这个模板,然后在新的模板上操作。
本文将致力于解决以下几个问题:
1.多次为某列设置数据有效性真的没有效果吗?
2.如何实现“删除”某列的数据有效性,即能多次为某列设置数据有效性
3.设置数据有效性时选项超过255个ASCLL码,即报String literals in formulas can't be bigger than 255 characters ASCII错误怎么解决
一、多次为某列设置数据有效性真的没有效果吗?
首先我在D盘放一个excel文件,待会用来操作

其中的内容是这样的,注意:部门这一列是并没有设置数据有效性,而我们一会要使用POI为其设置数据有效性

我用的POI依赖如下所示
<!--操作excel-->
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
<!--文件操作工具-->
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>
代码如下所示,每一行代码的作用都用注释写得清清楚楚。
package cn.waterch.partyconstruction.util;
import org.apache.commons.io.FileUtils;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddressList;
import java.io.File;
import java.io.FileOutputStream;
public class Test {
public static void main(String[] args) {
try {
//文件路径
String path = "D://test/origin-template.xls";
File originTemplateFile = new File(path);
//读取新的模板excel文件,考虑到兼容性,使用Excel 2007之前的格式
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(FileUtils.openInputStream(originTemplateFile));
//获取系统中的所有党支部名称
//List<String> branchList = branchService.getBranchNameTotal();
//用来作为数据有效性下拉列表的选项
String[] departments = new String[] {"部门1","部门2"};
//读取工作表sheet
HSSFSheet sheet = hssfWorkbook.getSheetAt(0);
//第一行需要格式化的单元格(单元格下标是从0开始的,且前6行用来写提示信息了,因此从第7行开始操作,其下标为6)
int firstRowNum = 6;
//最后一行需要格式化的单元格,默认格式化约200行,根据需要设置
int lastRowNum = 200;
//第6列,也就是每一行党支部的那一列都需要进行格式化
int colume = 6;
//需要进行格式化的范围
CellRangeAddres

最低0.47元/天 解锁文章





