Java 使用POI生成带联动下拉框的excel表格实例代码
发布时间 - 2026-01-11 03:16:35 点击率:次废话不多说了,直接给大家贴代码了,具体代码如下所示:
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import org.apache.poi.hssf.usermodel.DVConstraint;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFDataValidation;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.DataValidation;
import org.apache.poi.ss.usermodel.Name;
import org.apache.poi.ss.util.CellRangeAddressList;
public class ExcelLinkage {
// 样式
private HSSFCellStyle cellStyle;
// 初始化省份数据
private List<String> province = new ArrayList<String>(Arrays.asList("湖南",
"广东"));
// 初始化数据(湖南的市区)
private List<String> hnCity = new ArrayList<String>(Arrays.asList("长沙市",
"邵阳市"));
// 初始化数据(广东市区)
private List<String> gdCity = new ArrayList<String>(Arrays.asList("深圳市",
"广州市"));
public void setDataCellStyles(HSSFWorkbook workbook, HSSFSheet sheet) {
cellStyle = workbook.createCellStyle();
// 设置边框
cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
// 设置背景色
cellStyle.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);
cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
// 设置居中
cellStyle.setAlignment(HSSFCellStyle.ALIGN_LEFT);
// 设置字体
HSSFFont font = workbook.createFont();
font.setFontName("宋体");
font.setFontHeightInPoints((short) 11); // 设置字体大小
cellStyle.setFont(font);// 选择需要用到的字体格式
// 设置单元格格式为文本格式(这里还可以设置成其他格式,可以自行百度)
HSSFDataFormat format = workbook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("@"));
}
/**
* 创建数据域(下拉联动的数据)
*
* @param workbook
* @param hideSheetName
* 数据域名称
*/
private void creatHideSheet(HSSFWorkbook workbook, String hideSheetName) {
// 创建数据域
HSSFSheet sheet = workbook.createSheet(hideSheetName);
// 用于记录行
int rowRecord = 0;
// 获取行(从0下标开始)
HSSFRow provinceRow = sheet.createRow(rowRecord);
// 创建省份数据
this.creatRow(provinceRow, province);
// 根据省份插入对应的市信息
rowRecord++;
for (int i = 0; i < province.size(); i++) {
List<String> list = new ArrayList<String>();
// 我这里是写死的 , 实际中应该从数据库直接获取更好
if (province.get(i).toString().equals("湖南")) {
// 将省份名称放在插入市的第一列, 这个在后面的名称管理中需要用到
list.add(0, province.get(i).toString());
list.addAll(hnCity);
} else {
list.add(0, province.get(i).toString());
list.addAll(gdCity);
}
//获取行
HSSFRow Cityrow = sheet.createRow(rowRecord);
// 创建省份数据
this.creatRow(Cityrow, list);
rowRecord++;
}
}
/**
* 创建一列数据
*
* @param currentRow
* @param textList
*/
public void creatRow(HSSFRow currentRow, List<String> text) {
if (text != null) {
int i = 0;
for (String cellValue : text) {
// 注意列是从(1)下标开始
HSSFCell userNameLableCell = currentRow.createCell(i++);
userNameLableCell.setCellValue(cellValue);
}
}
}
/**
* 名称管理
*
* @param workbook
* @param hideSheetName
* 数据域的sheet名
*/
private void creatExcelNameList(HSSFWorkbook workbook, String hideSheetName) {
Name name;
name = workbook.createName();
// 设置省名称
name.setNameName("province");
name.setRefersToFormula(hideSheetName + "!$A$1:$"
+ this.getcellColumnFlag(province.size())+ "$1");
// 设置省下面的市
for (int i = 0; i < province.size(); i++) {
List<String> num = new ArrayList<String>();
if (province.get(i).toString().equals("湖南")) {
name = workbook.createName();
num.add(0,province.get(i).toString());
num.addAll(hnCity);
name.setNameName(province.get(i).toString());
name.setRefersToFormula(hideSheetName + "!$B$" + (i + 2) + ":$"
+ this.getcellColumnFlag(num.size()) + "$" + (i + 2));
} else {
name = workbook.createName();
num.add(0,province.get(i).toString());
num.addAll(gdCity);
name.setNameName(province.get(i).toString());
name.setRefersToFormula(hideSheetName + "!$B$" + (i + 2) + ":$"
+ this.getcellColumnFlag(num.size()) + "$" + (i + 2));
}
}
}
// 根据数据值确定单元格位置(比如:28-AB)
private String getcellColumnFlag(int num) {
String columFiled = "";
int chuNum = 0;
int yuNum = 0;
if (num >= 1 && num <= 26) {
columFiled = this.doHandle(num);
} else {
chuNum = num / 26;
yuNum = num % 26;
columFiled += this.doHandle(chuNum);
columFiled += this.doHandle(yuNum);
}
return columFiled;
}
private String doHandle(final int num) {
String[] charArr = { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J",
"K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
"W", "X", "Y", "Z" };
return charArr[num - 1].toString();
}
/**
* 使用已定义的数据源方式设置一个数据验证
*
* @param formulaString
* @param naturalRowIndex
* @param naturalColumnIndex
* @return
*/
public DataValidation getDataValidationByFormula(String formulaString,
int naturalRowIndex, int naturalColumnIndex) {
// 加载下拉列表内容
DVConstraint constraint = DVConstraint
.createFormulaListConstraint(formulaString);
// 设置数据有效性加载在哪个单元格上。
// 四个参数分别是:起始行、终止行、起始列、终止列
int firstRow = naturalRowIndex;
int lastRow = naturalRowIndex;
int firstCol = naturalColumnIndex - 1;
int lastCol = naturalColumnIndex - 1;
CellRangeAddressList regions = new CellRangeAddressList(firstRow,
lastRow, firstCol, lastCol);
// 数据有效性对象
DataValidation data_validation_list = new HSSFDataValidation(regions,
constraint);
return data_validation_list;
}
/**
* 创建一列数据
*
* @param hssfSheet
*/
public void creatAppRow(HSSFSheet hssfSheet, int naturalRowIndex) {
// 获取行
HSSFRow hssfRow = hssfSheet.createRow(naturalRowIndex);
HSSFCell province = hssfRow.createCell(0);
province.setCellValue("");
province.setCellStyle(cellStyle);
HSSFCell City = hssfRow.createCell(1);
City.setCellValue("");
City.setCellStyle(cellStyle);
// 得到验证对象
DataValidation data_validation_list1 = this.getDataValidationByFormula(
"province", naturalRowIndex, 1);
DataValidation data_validation_list2 = this
.getDataValidationByFormula("INDIRECT($A"
+ (naturalRowIndex + 1) + ")", naturalRowIndex, 2);
// 工作表添加验证数据
hssfSheet.addValidationData(data_validation_list1);
hssfSheet.addValidationData(data_validation_list2);
}
public void Export() {
try {
File file = new File("F:/excel.xls");
FileOutputStream outputStream = new FileOutputStream(file);
// 创建excel
HSSFWorkbook workbook = new HSSFWorkbook();
// 设置sheet 名称
HSSFSheet excelSheet = workbook.createSheet("excel");
// 设置样式
this.setDataCellStyles(workbook, excelSheet);
// 创建一个隐藏页和隐藏数据集
this.creatHideSheet(workbook, "shutDataSource");
// 设置名称数据集
this.creatExcelNameList(workbook, "shutDataSource");
// 创建一行数据
for (int i = 0; i < 50; i++) {
this.creatAppRow(excelSheet,i);
}
workbook.write(outputStream);
outputStream.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
ExcelLinkage linkage = new ExcelLinkage();
linkage.Export();
}
}
总结
以上所述是小编给大家介绍的Java 使用POI生成带联动下拉框的excel表格,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# java
# poi
# 联动下拉框excel表格
# Java实现Excel导入导出操作详解
# Java通过导出超大Excel文件解决内存溢出问题
# java中下拉框select和单选按钮的回显操作
# java AJAX实现级联下拉框
# Java 导出Excel增加下拉框选项
# 湖南
# 单元格
# 给大家
# 广东
# 邵阳市
# 小编
# 长沙市
# 加载
# 放在
# 还可以
# 在此
# 说了
# 不多
# 是从
# 广州市
# 深圳市
# 所示
# 在后面
# 所述
# 创建一个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
EditPlus中的正则表达式实战(5)
如何在云虚拟主机上快速搭建个人网站?
如何彻底卸载建站之星软件?
Python进程池调度策略_任务分发说明【指导】
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
Android Socket接口实现即时通讯实例代码
Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel PHP版本要求一览_Laravel各版本环境要求对照
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
linux top下的 minerd 木马清除方法
如何快速建站并高效导出源代码?
个人摄影网站制作流程,摄影爱好者都去什么网站?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
详解CentOS6.5 安装 MySQL5.1.71的方法
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
如何挑选优质建站一级代理提升网站排名?
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
如何用花生壳三步快速搭建专属网站?
详解Oracle修改字段类型方法总结
Laravel如何实现一对一模型关联?(Eloquent示例)
javascript中闭包概念与用法深入理解
javascript基本数据类型及类型检测常用方法小结
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
如何在阿里云香港服务器快速搭建网站?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
Python文本处理实践_日志清洗解析【指导】
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】
微信小程序 require机制详解及实例代码
香港服务器网站卡顿?如何解决网络延迟与负载问题?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
Laravel如何与Pusher实现实时通信?(WebSocket示例)
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
高性能网站服务器部署指南:稳定运行与安全配置优化方案
Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
重庆市网站制作公司,重庆招聘网站哪个好?
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
如何在IIS服务器上快速部署高效网站?

