如何使用 Java 在Excel中创建下拉列表

news/2024/7/21 7:30:47 标签: java, excel, 开发语言, 下拉列表

下拉列表(下拉框)可以确保用户仅从预先给定的选项中进行选择,这样不仅能减少数据输入错误,还能节省时间提高效率。在MS Excel中,我们可以通过 “数据验证” 提供的选项来创建下拉列表,但如果要在Java程序中通过代码实现这一功能,可能需要借助一些第三方库。本文将分享两种使用免费Java库在Excel中创建下拉列表的方法。

操作Excel的免费Java控件:Free Spire.XLS for Java. (下载后手动引入jar包或者通过Maven仓库安装均可)

方法一:基于字符串数组中的值来创建Excel下拉列表

该方法是通过 Free Spire.XLS for Java 提供的 IDataValidation 接口下的 setValue() 方法先定义一个字符串数组作为列表项,然后再通过将 isSuppressDropDownArrow() 方法的参数设置为false 来应用下拉箭头。

该方法就等同于在Excel “数据验证” 选项中的 “来源” 中直接输入一串内容作为列表项。

代码:

java">import com.spire.xls.*;
import java.awt.*;

public class ExcelDropdownList {
    public static void main(String[] args) {

        //创建Workbook对象
        Workbook workbook = new Workbook();

        //获取第一张工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        //在指定单元格中添加文本
        sheet.getCellRange("B2").setValue("职员");
        sheet.getCellRange("B3").setValue("张三");
        sheet.getCellRange("C2").setValue("部门");

        //设置字体和单元格样式
        sheet.getCellRange("B2:C2").getStyle().getFont().isBold(true);
        sheet.getCellRange("B2:C2").getStyle().getFont().setColor(Color.BLUE);
        sheet.getCellRange("B2:C3").getStyle().getFont().setSize(11);
        sheet.getCellRange("B2:C3").setRowHeight(18);
        sheet.getCellRange("B2:C3").setColumnWidth(12);

        //设置下拉列表的值
        sheet.getCellRange("C3").getDataValidation().setValues(new String[]{"财务部", "采购部", "销售部", "行政部"});

        //在指定单元格中创建下拉列表
        sheet.getCellRange("C3").getDataValidation().isSuppressDropDownArrow(false);

        //保存结果文件
        workbook.saveToFile("Excel下拉列表.xlsx", ExcelVersion.Version2013);
    }
}

 

方法二:基于单元格区域的内容来创建Excel下拉列表

该方法是通过 Validation 类的 setDataRange() 方法指定一个单元格区域中的内容作为下拉列表的数据源。该方法更加灵活,创建后如果你想更新下拉列表的选项,直接更新单元格中的数据即可。效果如图:

代码:

java">import com.spire.xls.*;
import java.awt.*;

public class DropdownList {
    public static void main(String[] args) {

        //创建Workbook对象
        Workbook workbook = new Workbook();

        //获取第一张工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        //在指定单元格中添加文本
        sheet.getCellRange("B2").setValue("职员");
        sheet.getCellRange("B3").setValue("张三");
        sheet.getCellRange("C2").setValue("部门");
        
        sheet.getCellRange("A11").setValue("财务部");
        sheet.getCellRange("A12").setValue("采购部");
        sheet.getCellRange("A13").setValue("销售部");
        sheet.getCellRange("A14").setValue("行政部");

        //设置字体和单元格样式
        sheet.getCellRange("B2:C2").getStyle().getFont().isBold(true);
        sheet.getCellRange("B2:C2").getStyle().getFont().setColor(Color.BLUE);
        sheet.getCellRange("B2:C3").getStyle().getFont().setSize(11);
        sheet.getCellRange("B2:C3").setRowHeight(18);
        sheet.getCellRange("B2:C3").setColumnWidth(12);

        //将指定的单元格区域的内容作为数据源来创建下拉列表
        sheet.getCellRange("C3:C4").getDataValidation().setDataRange(sheet.getCellRange("A11:A14"));

        //保存结果文件
        workbook.saveToFile("Excel下拉列表2.xlsx", ExcelVersion.Version2013);
    }
}

 

免费Free Spire.XLS for Java库支持多种Excel操作功能,但同时也存在一些限制。

了解功能点击:免费Java Excel组件中文教程icon-default.png?t=N7T8https://www.e-iceblue.cn/spirexlsforjava/spire-xls-for-java-program-guide-content.html


http://www.niftyadmin.cn/n/5221270.html

相关文章

品优购:nav导航、footer部分

目录 nav导航栏 footer部分 mod-copyright nav导航栏 nav盒子通栏有高度,有下边框 1号盒子左浮动,dropdown 2号盒子左侧浮动,navitems导航栏组 先看dropdown里,先表头,这里意思是description term, 然后是一系列表…

Redis部署脚本(完成-第一版)

主要包含redis的一键部署脚本和redis启动脚本文件 当前可以完成一键部署,还需改进语法 install.sh #!/bin/bash systemctl stop firewalld systemctl disable firewalld #!/bin/bash if ! command -v yum &> /dev/null; then echo -e "\e[31m yum…

【Unity的HDRP渲染管线VR性能优化_UNITY_SINGLE_PASS_STEREO和UNITY_STEREO_MULTIVIEW_ENABLED】

Unity VR性能优化 简单存留一下!!!!简单存留一下!!!! 看引擎内置的一些包含文件,然后看见下面这一段 //立体多例化渲染技术的核心思想是一次向渲染管道上提交两份待渲染的几何体数据,减少绘制调用 draw call 的次数,提升渲染性能。 #if defined(UNITY_SINGLE_PASS…

Java核心知识点整理大全19-笔记

目录 14.1.5.2. MemStore 刷盘 全局内存控制 MemStore 达到上限 RegionServer 的 Hlog 数量达到上限 手工触发 关闭 RegionServer 触发 Region 使用 HLOG 恢复完数据后触发 14.1.6.HBase vs Cassandra 15. MongoDB 15.1.1. 概念 15.1.2. 特点 16. Cassandra 16.1.1…

AI 绘画 | Stable Diffusion 提示词扩展插件

前言 提示词对于Stable Diffusion AI绘画来说非常重要, 由于Stable Diffusion 支持英文提示词,对于英文不好的朋友,每次都要切换翻译网站去翻译,很不方便,下面介绍两款Stable Diffusion 提示词扩展插件,让你写提示词更轻松。 sd-webui-prompt-all-in-one 提示词多合一插…

居家适老化设计第三十三条---卫生间之暖风

居家适老化是指为了满足老年人居住需求而进行的住房改造,以提供更加安全、舒适、便利的居住环境。在居家适老化中,暖风系统是一个重要的考虑因素。暖风系统可以提供温暖舒适的室内温度,对老年人来说尤为重要。老年人常常身体机能下降&#xf…

1146:吃糖果(C语言)

题目描述 HOHO,终于从Speakless手上赢走了所有的糖果,是Gardon吃糖果时有个特殊的癖好,就是不喜欢连续两次吃一样的糖果,喜欢先吃一颗A种类的糖果,下一次换一种口味,吃一颗B种类的糖果,这样&…

【SA8295P 源码分析】134 - Android 侧 NFS Client 挂载 QNX NFS Server 目录不成功 问题排查方法

【SA8295P 源码分析】134 - Android 侧 NFS Client 挂载 QNX NFS Server 目录不成功 问题排查方法 一、QNX侧1. 检查镜像是否挂载成功:/mnt/nfs_shared_dir 目录2. 检查 /mnt/etc/exports 文件配置是否正确3. 检查 nfsd、rpcbind 两个服务程序是否在后台工作正常二、Android 检…