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

打印 上一主题 下一主题

主题 868|帖子 868|积分 2604

下拉列表(下拉框)可以确保用户仅从预先给定的选项中进行选择,这样不仅能减少数据输入错误,还能节流时间提高效率。在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代码:
  1. import com.spire.xls.*;
  2. import java.awt.*;
  3. public class ExcelDropdownList {
  4.     public static void main(String[] args) {
  5.         //创建Workbook对象
  6.         Workbook workbook = new Workbook();
  7.         //获取第一张工作表
  8.         Worksheet sheet = workbook.getWorksheets().get(0);
  9.         //在指定单元格中添加文本
  10.         sheet.getCellRange("B2").setValue("职员");
  11.         sheet.getCellRange("B3").setValue("张三");
  12.         sheet.getCellRange("C2").setValue("部门");
  13.         //设置字体和单元格样式
  14.         sheet.getCellRange("B2:C2").getStyle().getFont().isBold(true);
  15.         sheet.getCellRange("B2:C2").getStyle().getFont().setColor(Color.BLUE);
  16.         sheet.getCellRange("B2:C3").getStyle().getFont().setSize(11);
  17.         sheet.getCellRange("B2:C3").setRowHeight(18);
  18.         sheet.getCellRange("B2:C3").setColumnWidth(12);
  19.         //设置下拉列表的值
  20.         sheet.getCellRange("C3").getDataValidation().setValues(new String[]{"财务部", "采购部", "销售部", "行政部"});
  21.         //在指定单元格中创建下拉列表
  22.         sheet.getCellRange("C3").getDataValidation().isSuppressDropDownArrow(false);
  23.         //保存结果文件
  24.         workbook.saveToFile("Excel下拉列表.xlsx", ExcelVersion.Version2013);
  25.     }
  26. }
复制代码
 
方法二:基于单元格区域的内容来创建Excel下拉列表

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

 
Java代码:
  1. import com.spire.xls.*;
  2. import java.awt.*;
  3. public class DropdownList {
  4.     public static void main(String[] args) {
  5.         //创建Workbook对象
  6.         Workbook workbook = new Workbook();
  7.         //获取第一张工作表
  8.         Worksheet sheet = workbook.getWorksheets().get(0);
  9.         //在指定单元格中添加文本
  10.         sheet.getCellRange("B2").setValue("职员");
  11.         sheet.getCellRange("B3").setValue("张三");
  12.         sheet.getCellRange("C2").setValue("部门");
  13.         
  14.         sheet.getCellRange("A11").setValue("财务部");
  15.         sheet.getCellRange("A12").setValue("采购部");
  16.         sheet.getCellRange("A13").setValue("销售部");
  17.         sheet.getCellRange("A14").setValue("行政部");
  18.         //设置字体和单元格样式
  19.         sheet.getCellRange("B2:C2").getStyle().getFont().isBold(true);
  20.         sheet.getCellRange("B2:C2").getStyle().getFont().setColor(Color.BLUE);
  21.         sheet.getCellRange("B2:C3").getStyle().getFont().setSize(11);
  22.         sheet.getCellRange("B2:C3").setRowHeight(18);
  23.         sheet.getCellRange("B2:C3").setColumnWidth(12);
  24.         //将指定的单元格区域的内容作为数据源来创建下拉列表
  25.         sheet.getCellRange("C3:C4").getDataValidation().setDataRange(sheet.getCellRange("A11:A14"));
  26.         //保存结果文件
  27.         workbook.saveToFile("Excel下拉列表2.xlsx", ExcelVersion.Version2013);
  28.     }
  29. }
复制代码
 
免费Free Spire.XLS for Java库支持多种Excel操作功能,但同时也存在一些限制
点击相识更多功能:https://www.e-iceblue.cn/spirexlsforjava/spire-xls-for-java-program-guide-content.html

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

我爱普洱茶

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表