全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Java 使用POI生成带联动下拉框的excel表格实例代码

废话不多说了,直接给大家贴代码了,具体代码如下所示:

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增加下拉框选项  # 湖南  # 单元格  # 给大家  # 广东  # 邵阳市  # 小编  # 长沙市  # 加载  # 放在  # 还可以  # 在此  # 说了  # 不多  # 是从  # 广州市  # 深圳市  # 所示  # 在后面  # 所述  # 创建一个 


相关文章: IOS倒计时设置UIButton标题title的抖动问题  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  广东企业建站网站优化与SEO营销核心策略指南  桂林网站制作公司有哪些,桂林马拉松怎么报名?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  Python路径拼接规范_跨平台处理说明【指导】  教学论文网站制作软件有哪些,写论文用什么软件 ?  香港网站服务器数量如何影响SEO优化效果?  如何用免费手机建站系统零基础打造专业网站?  建站之星2.7模板快速切换与批量管理功能操作指南  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  定制建站方案优化指南:企业官网开发与建站费用解析  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  如何快速打造个性化非模板自助建站?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  南京网站制作费用,南京远驱官方网站?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何在服务器上三步完成建站并提升流量?  如何配置FTP站点权限与安全设置?  网站制作网站,深圳做网站哪家比较好?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  大型企业网站制作流程,做网站需要注册公司吗?  如何在香港服务器上快速搭建免备案网站?  C++如何编写函数模板?(泛型编程入门)  自助网站制作软件,个人如何自助建网站?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  如何选择美橙互联多站合一建站方案?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何通过WDCP绑定主域名及创建子域名站点?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  如何快速搭建FTP站点实现文件共享?  b2c电商网站制作流程,b2c水平综合的电商平台?  建站与域名管理如何高效结合?  网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?  nginx修改上传文件大小限制的方法  c# 服务器GC和工作站GC的区别和设置  如何在云服务器上快速搭建个人网站?  红河网站制作公司,红河事业单位身份证如何上传? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。