1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Java如何使用POI生成联动下拉框的excel表格实例

Java如何使用POI生成联动下拉框的excel表格实例

时间:2019-06-06 14:53:09

相关推荐

Java如何使用POI生成联动下拉框的excel表格实例

Java|java教程

Java,联动,生成

Java-java教程

本文通过实例代码给大家分享Java 使用POI生成带联动下拉框的excel表格,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下吧

易语言替换源码,vscode搜索文件快捷方式,魅族ubuntu下载,tomcat服务调用日志,sqlite 修改视图,网页设计都用什么软件,服务器怎么连接ftp,cityselect插件下载,前端框架指令04,爬虫的好坏,php用户手册,seo的出路,开源好的springboot,公安网站后台管理系统,全景图生成网页,游戏介绍网站模板,谷歌浏览器后台更新,wordpress 登陆页面,基于web管理系统,万能克隆小偷程序lzw

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

超强seo 源码,ubuntu安装pi节点,爬虫有人养吗,php .json,seo网上授课lzw

自动采集360网站源码,vscode输入全选中状态,ubuntu 左边框,tomcat修改连接超时,网络爬虫演示,js获取php json,大连网络营销seo,点位盘网站源码,网博士模板列表lzw

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 province = new ArrayList(Arrays.asList("湖南", "广东")); // 初始化数据(湖南的市区) private List hnCity = new ArrayList(Arrays.asList("长沙市", "邵阳市")); // 初始化数据(广东市区) private List gdCity = new ArrayList(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 list = new ArrayList(); // 我这里是写死的 , 实际中应该从数据库直接获取更好 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 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 num = new ArrayList(); 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(); }}

总结

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。