POI生成Excel文件增加数据验证(下拉序列)

POI版本为5.2.2

正常的如果不超过255字符的数据验证可以参照如下代码:

/*** <p>设置某列的数据验证</p>* @param Sheet 作用于哪一个sheet* @param colIndex 需要增加数据验证的列的索引* @String[] names 数据验证的序列,就是excel下拉列表的内容*/
public static void setDataValidation(Sheet sheet, int colIndex, String[] names) {//直接用给定的数据创建显式序列DataValidationConstraint constraint = sheet.getDataValidationHelper().createExplicitListConstraint(names);constraint.setOperator(DataValidationConstraint.OperatorType.BETWEEN);//创建一个区域,某列的第2行到第65535行,一般第一行是标题列CellRangeAddressList addressList = new CellRangeAddressList(1,65535,colIndex,colIndex);DataValidation validation = sheet.getDataValidationHelper().createValidation(constraint, addressList);validation.setErrorStyle(DataValidation.ErrorStyle.STOP);//不允许单元格为空validation.setEmptyCellAllowed(false);validation.setShowErrorBox(true);//添加数据验证到sheet中sheet.addValidationData(validation);
}@Test
public void test(){Workbook workbook = WorkbookFactory.create(true);//xlsxSheet sheet = workbook.createSheet("测试");//先创建65535行for (int i = 0; i < 65535; i++) {Row row = sheet.getRow(i);if (Objects.isNull(row))row=sheet.createRow(i);Cell cell = row.getCell(0);if (Objects.isNull(cell))cell = row.createCell(0);}//下拉列表的数据String[] strs = {"借","贷"};setDataValidation(sheet,0,strs);workbook.write(new FileOutputStream("D:\\poitest\\测试.xlsx"));
}

 

由于excel数据验证 序列的长度最多255字符, 如果代码中数据的长度超过这个,则生成的excel会提示先修复才能打开,修复完成打开之后发现需要设置数据验证的列没有设置成功。如果想要输入更多数据,则先可以先把数据保存到一个隐藏的sheet中,然后通过公式引用存储的数据再设置数据验证。

/*** <p>设置某列的数据验证</p>* @param Sheet 作用于哪一个sheet* @param colIndex 需要增加数据验证的列的索引* @String formula 公式,引用隐藏sheet的数据*/
public static void setDataValidationByFormula(Sheet sheet, int colIndex, String formula) {//直接用给定的公式创建DataValidationConstraint constraint = sheet.getDataValidationHelper().createFormulaListConstraint(formula);constraint.setOperator(DataValidationConstraint.OperatorType.BETWEEN);//创建一个区域,某列的第2行到第65535行,一般第一列是标题列CellRangeAddressList addressList = new CellRangeAddressList(1,65535,colIndex,colIndex);DataValidation validation = sheet.getDataValidationHelper().createValidation(constraint, addressList);validation.setErrorStyle(DataValidation.ErrorStyle.STOP);//不允许单元格为空validation.setEmptyCellAllowed(false);validation.setShowErrorBox(true);//添加数据验证到sheet中sheet.addValidationData(validation);
}@Test
public void test(){Workbook workbook = WorkbookFactory.create(true);//xlsxSheet sheet = workbook.createSheet("测试");//先创建65535行for (int i = 0; i < 65535; i++) {Row row = sheet.getRow(i);if (Objects.isNull(row))row=sheet.createRow(i);Cell cell = row.getCell(0);if (Objects.isNull(cell))cell = row.createCell(0);}//下拉列表的数据,一般从数据库取出List<String> acctitleList = getAcctitleList();Sheet hiddenSheet = workbook.createSheet("hidden");for (int i = 0; i < acctitleList.size(); i++) {Row row = hiddenSheet.createRow(i);Cell cell = row.createCell(0);cell.setCellValue(acctitleList.get(i));}//hidden 的索引为1,隐藏sheetworkbook.setSheetHidden(1,true);//格式为  sheet名字!$起始列名$起始行号:$结束列名$结束行号String formula = "hidden!$A$1:$A$"+acctitleList.size();setDataValidation(sheet,0,formula);workbook.write(new FileOutputStream("D:\\poitest\\测试.xlsx"));
}
/*** 模拟从数据库中取数据*/
private List<String> getAcctitleList(){List<String> list = new ArrayList<>();list.add("6405020000 | 税金及附加-土地增值税");list.add("6405090000 | 税金及附加-城市维护建设税");list.add("6405100000 | 税金及附加-教育费附加");list.add("6405030000 | 税金及附加-房产税");list.add("6405040000 | 税金及附加-土地使用税");list.add("6405110000 | 税金及附加-地方教育附加");list.add("6405080000 | 税金及附加-印花税");list.add("6405120000 | 税金及附加-水利建设基金");list.add("2221210000 | 应交税费-应交城市维护建设税");list.add("2221140000 | 应交税费-应交土地增值税");list.add("2221220000 | 应交税费-应交教育费附加");list.add("2221150000 | 应交税费-应交房产税");list.add("2221160000 | 应交税费-应交土地使用税");list.add("2221230000 | 应交税费-应交地方教育费附加");list.add("2221200000 | 应交税费-应交印花税");list.add("2221240000 | 应交税费-水利建设基金");list.add("5005040400 | 服务成本-劳务费-保绿费");list.add("2241050000 | 其他应付款-暂估/预提费");return list;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/879553.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

持续集成与持续交付CI/CD

CI/CD 是指持续集成&#xff08;Continuous Integration&#xff09;和持续部署&#xff08;Continuous Deployment&#xff09;或持续交付&#xff08;Continuous Delivery&#xff09; 持续集成&#xff08;Continuous Integration&#xff09; 持续集成是一种软件开发实践&…

HTML贪吃蛇游戏

文章目录 贪吃蛇游戏 运行效果代码 贪吃蛇游戏 贪吃蛇是一款经典的休闲益智游戏。本文将通过HTML5和JavaScript详细解析如何实现一个简易版的贪吃蛇游戏。游戏的主要逻辑包括蛇的移动、碰撞检测、食物生成等功能。以下是游戏的完整代码及注释解析。&#xff08;纯属好玩&#…

(学习总结17)C++继承

C继承 一、继承的概念与定义继承的概念继承定义1. 定义格式2. 继承基类成员访问方式的变化 继承类模板 二、基类和派生类间的转换三、继承中的作用域隐藏规则 四、派生类的默认成员函数4个常见默认成员函数实现一个不能被继承的类 五、继承与友元六、继承与静态成员七、多继承及…

HTML 揭秘:HTML 编码快速入门

HTML 揭秘&#xff1a;HTML 编码快速入门 一 . 前端知识介绍二 . HTML 介绍三 . HTML 快速入门四 . HTML 编辑器 - VSCode4.1 插件安装4.2 修改主题配色4.3 修改快捷键4.4 设置自动保存4.5 创建 HTML 文件4.5 书写 HTML 代码4.6 常见快捷键 五 . 基础标签5.1 字体标签5.1.1 col…

物品识别——基于python语言

目录 1.物品识别 2.模型介绍 3.文件框架 4.代码示例 4.1 camera.py 4.2 interaction.py 4.3 object_detection.py 4.4 main.py 4.5 运行结果 5.总结 1.物品识别 该项目使用Python&#xff0c;OpenCV进行图像捕捉&#xff0c;进行物品识别。我们将使用YOLO&#xff08…

大数据处理技术:HBase的安装与基本操作

目录 1 实验名称 2 实验目的 3 实验内容 4 实验原理 5 实验过程或源代码 5.1 Hbase数据库的安装 5.2 创建表 5.3 添加数据、删除数据、删除表 5.4 使用Java操作HBase 6 实验结果 6.1 Hbase数据库的安装 6.2 创建表 6.3 添加数据、删除数据、删除表 6.4 使用Java操…

【Elasticsearch系列七】索引 crud

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

数据结构(Day13)

一、学习内容 内存空间划分 1、一个进程启动后&#xff0c;计算机会给该进程分配4G的虚拟内存 2、其中0G-3G是用户空间【程序员写代码操作部分】【应用层】 3、3G-4G是内核空间【与底层驱动有关】 4、所有进程共享3G-4G的内核空间&#xff0c;每个进程独立拥有0G-3G的用户空间 …

[数据集][目标检测]烟叶病害检测数据集VOC+YOLO格式612张3类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;612 标注数量(xml文件个数)&#xff1a;612 标注数量(txt文件个数)&#xff1a;612 标注类别…

【鸿蒙】HarmonyOS NEXT星河入门到实战7-ArkTS语法进阶

目录 1、Class类 1.1 Class类 实例属性 1.2 Class类 构造函数 1.3 Class类 定义方法 1.4 静态属性 和 静态方法 1.5 继承 extends 和 super 关键字 1.6 instanceof 检测是否实例 1.7.修饰符(readonly、private、protected 、public) 1.7.1 readonly 1.7.2 Private …

汽车免拆诊断案例 | 沃尔沃V40 1.9TD断续工作

故障现象 一辆04款的沃尔沃V40 1.9 TD&#xff0c;发动机代码D4192T3&#xff0c;使用博世EDC15C发动机管理。客户说车子断续工作&#xff0c;怀疑是正时皮带出现问题。卸下上皮带盖&#xff0c;检查发现皮带仍然在原来的位置上并且没有出现松动。起动发动机&#xff0c;车辆能…

安卓玩机工具-----ADB与 FASTBOOT模式 图形化 多功能玩机刷机工具

工具说明 这款工具是英文版。易于使用的工具提供了用于运行 ADB 和 Fastboot 命令的图形用户界面。ADB 功能包括旁加载、安装和卸载应用程序、测试设备以及重新启动到不同的模式。可以使用 fastboot 命令进行设备管理;其中包括检查 Antirollback 和 active slots 等变…

YOLOv8 人体姿态估计动作识别关键点检测(代码+教程)

YOLOv8 人体姿态判断 项目介绍 YOLOv8 人体姿态判断 是一个基于最新YOLOv8模型的深度学习项目&#xff0c;旨在识别和分析人体姿态。该项目利用先进的计算机视觉技术和深度学习框架&#xff0c;通过摄像头捕捉实时图像或处理存储图像&#xff0c;识别人体的关键点&#xff0c…

在线查看 Android 系统源代码 AOSPXRef and AndroidXRef

在线查看 Android 系统源代码 AOSPXRef and AndroidXRef 1. AOSPXRef1.1. http://aospxref.com/android-14.0.0_r2/1.2. build/envsetup.sh 2. AndroidXRef2.1. http://androidxref.com/9.0.0_r3/2.2. build/envsetup.sh 3. HELLO AndroidReferences 1. AOSPXRef http://aospx…

加密与安全_优雅存储用户密码的最佳实践

文章目录 Pre概述最佳实践避免使用MD5、SHA1等快速哈希算法加盐哈希 &#xff08;不推荐&#xff09;使用BCrypt、Argon2等慢哈希算法 (推荐)BCrypt Code1. 自动生成和嵌入盐2. 哈希结果的格式3. 代价因子 BCrypt特点 防止暴力破解1. 登录失败锁定2. 双因素认证&#xff08;2FA…

Golang | Leetcode Golang题解之第409题最长回文串

题目&#xff1a; 题解&#xff1a; func longestPalindrome(s string) int {mp : map[byte]int{}for i : 0; i < len(s); i {mp[s[i]]}res : 0for _, v : range mp {if v&1 1 {res v - 1} else {res v}}if res<len(s) {res}return res }

Python酷库之旅-第三方库Pandas(117)

目录 一、用法精讲 516、pandas.DataFrame.add_suffix方法 516-1、语法 516-2、参数 516-3、功能 516-4、返回值 516-5、说明 516-6、用法 516-6-1、数据准备 516-6-2、代码示例 516-6-3、结果输出 517、pandas.DataFrame.align方法 517-1、语法 517-2、参数 51…

Go语言基本语法

Go语言&#xff08;通常称为Golang&#xff09;是由Google开发的一种静态类型、编译型语言&#xff0c;它旨在简化系统编程、网络编程和并发编程的复杂性。 Go语言以其简洁、高效和易于理解的语法而受到开发者的喜爱。 Go语言的一些基本语法元素&#xff1a; 1. 包&#xff…

protobuf中c、c++、python使用

文章目录 protobuf实例&#xff1a;例题1&#xff1a;[CISCN 2023 初赛]StrangeTalkBot分析&#xff1a;思路&#xff1a;利用&#xff1a; 例题2&#xff1a;[CISCN 2024]protoverflow分析&#xff1a; protobuf Protocol Buffers&#xff0c;是Google公司开发的一种数据描述语…

数学学习记录

9月14日 1.映射&#xff1a; 2.函数: 9月15日 3.反函数&#xff1a; 4.收敛数列的性质 5.反三角函数&#xff1a; 9月16日 6.函数的极限&#xff1a; 7.无穷小和无穷大 极限运算法则&#xff1a;