欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 使用POI生成帶聯(lián)動(dòng)下拉框的excel表格實(shí)例代碼

 更新時(shí)間:2017年09月15日 17:14:53   作者:QQQT  
本文通過(guò)實(shí)例代碼給大家分享Java 使用POI生成帶聯(lián)動(dòng)下拉框的excel表格,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧

廢話不多說(shuō)了,直接給大家貼代碼了,具體代碼如下所示:

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;
 // 初始化省份數(shù)據(jù)
 private List<String> province = new ArrayList<String>(Arrays.asList("湖南",
   "廣東"));
 // 初始化數(shù)據(jù)(湖南的市區(qū))
 private List<String> hnCity = new ArrayList<String>(Arrays.asList("長(zhǎng)沙市",
   "邵陽(yáng)市"));
 // 初始化數(shù)據(jù)(廣東市區(qū))
 private List<String> gdCity = new ArrayList<String>(Arrays.asList("深圳市",
   "廣州市"));
 public void setDataCellStyles(HSSFWorkbook workbook, HSSFSheet sheet) {
  cellStyle = workbook.createCellStyle();
  // 設(shè)置邊框
  cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
  cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
  // 設(shè)置背景色
  cellStyle.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);
  cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
  // 設(shè)置居中
  cellStyle.setAlignment(HSSFCellStyle.ALIGN_LEFT);
  // 設(shè)置字體
  HSSFFont font = workbook.createFont();
  font.setFontName("宋體");
  font.setFontHeightInPoints((short) 11); // 設(shè)置字體大小
  cellStyle.setFont(font);// 選擇需要用到的字體格式
  // 設(shè)置單元格格式為文本格式(這里還可以設(shè)置成其他格式,可以自行百度)
  HSSFDataFormat format = workbook.createDataFormat();
  cellStyle.setDataFormat(format.getFormat("@"));
 }
 /**
  * 創(chuàng)建數(shù)據(jù)域(下拉聯(lián)動(dòng)的數(shù)據(jù))
  * 
  * @param workbook
  * @param hideSheetName
  *   數(shù)據(jù)域名稱
  */
 private void creatHideSheet(HSSFWorkbook workbook, String hideSheetName) {
  // 創(chuàng)建數(shù)據(jù)域
  HSSFSheet sheet = workbook.createSheet(hideSheetName);
  // 用于記錄行
  int rowRecord = 0;
  // 獲取行(從0下標(biāo)開(kāi)始)
  HSSFRow provinceRow = sheet.createRow(rowRecord);
  // 創(chuàng)建省份數(shù)據(jù)
  this.creatRow(provinceRow, province);
  // 根據(jù)省份插入對(duì)應(yīng)的市信息
  rowRecord++;
  for (int i = 0; i < province.size(); i++) {
   List<String> list = new ArrayList<String>();
   // 我這里是寫死的 , 實(shí)際中應(yīng)該從數(shù)據(jù)庫(kù)直接獲取更好
   if (province.get(i).toString().equals("湖南")) {
    // 將省份名稱放在插入市的第一列, 這個(gè)在后面的名稱管理中需要用到
    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);
   // 創(chuàng)建省份數(shù)據(jù)
   this.creatRow(Cityrow, list);
   rowRecord++;
  }
 }
 /**
  * 創(chuàng)建一列數(shù)據(jù)
  * 
  * @param currentRow
  * @param textList
  */
 public void creatRow(HSSFRow currentRow, List<String> text) {
  if (text != null) {
   int i = 0;
   for (String cellValue : text) {
    // 注意列是從(1)下標(biāo)開(kāi)始
    HSSFCell userNameLableCell = currentRow.createCell(i++);
    userNameLableCell.setCellValue(cellValue);
   }
  }
 }
 /**
  * 名稱管理
  * 
  * @param workbook
  * @param hideSheetName
  *   數(shù)據(jù)域的sheet名
  */
 private void creatExcelNameList(HSSFWorkbook workbook, String hideSheetName) {
  Name name;
  name = workbook.createName();
  // 設(shè)置省名稱
  name.setNameName("province");
  name.setRefersToFormula(hideSheetName + "!$A$1:$"
    + this.getcellColumnFlag(province.size())+ "$1");
  // 設(shè)置省下面的市
  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));
   }
  }
 }
 // 根據(jù)數(shù)據(jù)值確定單元格位置(比如: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();
 }
 /**
  * 使用已定義的數(shù)據(jù)源方式設(shè)置一個(gè)數(shù)據(jù)驗(yàn)證
  * 
  * @param formulaString
  * @param naturalRowIndex
  * @param naturalColumnIndex
  * @return
  */
 public DataValidation getDataValidationByFormula(String formulaString,
   int naturalRowIndex, int naturalColumnIndex) {
  // 加載下拉列表內(nèi)容
  DVConstraint constraint = DVConstraint
    .createFormulaListConstraint(formulaString);
  // 設(shè)置數(shù)據(jù)有效性加載在哪個(gè)單元格上。
  // 四個(gè)參數(shù)分別是:起始行、終止行、起始列、終止列
  int firstRow = naturalRowIndex;
  int lastRow = naturalRowIndex;
  int firstCol = naturalColumnIndex - 1;
  int lastCol = naturalColumnIndex - 1;
  CellRangeAddressList regions = new CellRangeAddressList(firstRow,
    lastRow, firstCol, lastCol);
  // 數(shù)據(jù)有效性對(duì)象
  DataValidation data_validation_list = new HSSFDataValidation(regions,
    constraint);
  return data_validation_list;
 }
 /**
  * 創(chuàng)建一列數(shù)據(jù)
  * 
  * @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);
  // 得到驗(yàn)證對(duì)象
  DataValidation data_validation_list1 = this.getDataValidationByFormula(
    "province", naturalRowIndex, 1);
  DataValidation data_validation_list2 = this
    .getDataValidationByFormula("INDIRECT($A"
      + (naturalRowIndex + 1) + ")", naturalRowIndex, 2);
  // 工作表添加驗(yàn)證數(shù)據(jù)
  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);
   // 創(chuàng)建excel
   HSSFWorkbook workbook = new HSSFWorkbook();
   // 設(shè)置sheet 名稱
   HSSFSheet excelSheet = workbook.createSheet("excel");
   // 設(shè)置樣式
   this.setDataCellStyles(workbook, excelSheet);
   // 創(chuàng)建一個(gè)隱藏頁(yè)和隱藏?cái)?shù)據(jù)集
   this.creatHideSheet(workbook, "shutDataSource");
   // 設(shè)置名稱數(shù)據(jù)集
   this.creatExcelNameList(workbook, "shutDataSource");
   // 創(chuàng)建一行數(shù)據(jù)
   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();
 }
}

總結(jié)

以上所述是小編給大家介紹的Java 使用POI生成帶聯(lián)動(dòng)下拉框的excel表格,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Java并發(fā)編程示例(八):處理線程的非受檢異常

    Java并發(fā)編程示例(八):處理線程的非受檢異常

    這篇文章主要介紹了Java并發(fā)編程示例(八):處理線程的非受檢異常,Java為我們提供了一種機(jī)制,專門用于處理由Thread對(duì)象拋出的非受檢異常,以避免程序的退出,需要的朋友可以參考下
    2014-12-12
  • Java Integer.ValueOf()的一些了解

    Java Integer.ValueOf()的一些了解

    這篇文章主要介紹了Java Integer.ValueOf()的一些了解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • 詳細(xì)聊聊Mybatis中萬(wàn)能的Map

    詳細(xì)聊聊Mybatis中萬(wàn)能的Map

    最近有個(gè)需求,就是使用mybatis時(shí),向mysql中插入數(shù)據(jù),其參數(shù)為map類型,下面這篇文章主要給大家介紹了關(guān)于Mybatis中萬(wàn)能的Map的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • 詳解Java中的迭代迭代器Iterator與枚舉器Enumeration

    詳解Java中的迭代迭代器Iterator與枚舉器Enumeration

    Iterator與Enumeration分別是實(shí)現(xiàn)迭代器和枚舉器類的接口,下面就帶大家來(lái)詳解Java中的迭代迭代器Iterator與枚舉器Enumeration,以及它們之間的區(qū)別.
    2016-05-05
  • Spring TaskScheduler使用實(shí)例解析

    Spring TaskScheduler使用實(shí)例解析

    這篇文章主要介紹了Spring TaskScheduler使用實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Java字符串常量池和intern方法解析

    Java字符串常量池和intern方法解析

    本文主要介紹了Java字符串常量池和intern方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Mac系統(tǒng)搭建JDK及JMETER過(guò)程解析

    Mac系統(tǒng)搭建JDK及JMETER過(guò)程解析

    這篇文章主要介紹了Mac系統(tǒng)搭建JDK及JMETER過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • SpringBoot無(wú)法識(shí)別bootstrap.yml小綠葉問(wèn)題的解決辦法

    SpringBoot無(wú)法識(shí)別bootstrap.yml小綠葉問(wèn)題的解決辦法

    一般單獨(dú)使用?Spring?Boot?時(shí),bootstrap.yml?文件一般是不會(huì)生效的,也就是沒(méi)有小綠葉圖標(biāo),本文給大家介紹了SpringBoot無(wú)法識(shí)別bootstrap.yml小綠葉問(wèn)題的解決辦法,文中給出了兩種解決方案,需要的朋友可以參考下
    2024-07-07
  • java編程經(jīng)典案例之基于斐波那契數(shù)列解決兔子問(wèn)題實(shí)例

    java編程經(jīng)典案例之基于斐波那契數(shù)列解決兔子問(wèn)題實(shí)例

    這篇文章主要介紹了java編程經(jīng)典案例之基于斐波那契數(shù)列解決兔子問(wèn)題,結(jié)合完整實(shí)例形式分析了斐波那契數(shù)列的原理及java解決兔子問(wèn)題的相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • JAVA 使用正則提取A標(biāo)簽以及href鏈接

    JAVA 使用正則提取A標(biāo)簽以及href鏈接

    這篇文章主要介紹了JAVA 使用正則提取A標(biāo)簽以及href鏈接的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評(píng)論