POI删除Excel中数据有效性

        读到这篇文章,请停下您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
评论 5
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值