XSSF实现Excel下拉和HSSF实现Excel下拉

有一种情况,初始化一个列时能用这种方法,但在循环调用时却不能制造多个下拉,原因是输入输出流的问题,每做完一列的下拉就要关闭流关闭文件,然后再打开就可以制造多个列了,不能一次制造多个列的下拉。

HSSF:

  1. public class POI  
  2.   {  
  3.   public static void main(String [] args)  
  4.   {  
  5.   String [] list={"东软","华信","SAP","海辉"};  
  6.   new POI().createListBox(list);  
  7.   
  8.   return;  
  9.   
  10.   }  
  11.   
  12.   public void createListBox (String [] list)  
  13.   
  14.   {  
  15.   
  16.   //文件初始化  
  17.   
  18.   HSSFWorkbook wb = new HSSFWorkbook();  
  19.   
  20.   HSSFSheet sheet = wb.createSheet("new sheet");  
  21.   
  22.   //在第一行第一个单元格,插入下拉框  
  23.   
  24.   HSSFRow row = sheet.createRow(0);  
  25.   
  26.   HSSFCell cell = row.createCell(0);  
  27.   
  28.   //普通写入操作  
  29.   
  30.   cell.setCellValue("请选择");//这是实验  
  31.   
  32.   //生成下拉列表  
  33.   
  34.   //只对(0,0)单元格有效  
  35.   
  36.   CellRangeAddressList regions = new CellRangeAddressList(0,0,0,0);  
  37.   
  38.   //生成下拉框内容  
  39.   
  40.   DVConstraint constraint = DVConstraint.createExplicitListConstraint(list);  
  41.   
  42.   //绑定下拉框和作用区域  
  43.   
  44.   HSSFDataValidation data_validation = new HSSFDataValidation(regions,constraint);  
  45.   
  46.   //对sheet页生效  
  47.   
  48.   sheet.addValidationData(data_validation);  
  49.   
  50.   //写入文件  
  51.   
  52.   FileOutputStream fileOut;  
  53.   
  54.   try {  
  55.   
  56.   fileOut = new FileOutputStream("workbook.xls");  
  57.   
  58.   wb.write(fileOut);  
  59.   
  60.   fileOut.close();  
  61.   
  62.   } catch (Exception e) {  
  63.   
  64.   // TODO Auto-generated catch block  
  65.   
  66.   e.printStackTrace();  
  67.   
  68.   }  
  69.   
  70.   //结束  
  71.   
  72.   System.out.println("Over");  
  73.   
  74.   }  
  75.   
  76.   }  

XSSF:

public class Xiala {
public static void main(String[] args) {
   try 
   {
       dropDownList42007("D:\\test.xlsx");
   } 
   catch (Exception e) {


       e.printStackTrace();
   }
}




public static void dropDownList42007(String filePath)
       throws Exception {
   XSSFWorkbook workbook = new XSSFWorkbook();
   XSSFSheet sheet = workbook.createSheet("下拉列表测试");
   String[] datas = new String[] {"维持","恢复","调整"};
   XSSFDataValidationHelper dvHelper = new XSSFDataValidationHelper(sheet);
   XSSFDataValidationConstraint dvConstraint = (XSSFDataValidationConstraint) dvHelper
           .createExplicitListConstraint(datas);
   CellRangeAddressList addressList = null;
   XSSFDataValidation validation = null;
    
       addressList = new CellRangeAddressList(1, 100, 0, 0);
       validation = (XSSFDataValidation) dvHelper.createValidation(
               dvConstraint, addressList);
       // 07默认setSuppressDropDownArrow(true);
       // validation.setSuppressDropDownArrow(true);
       // validation.setShowErrorBox(true);
       sheet.addValidationData(validation);
    
   FileOutputStream stream = new FileOutputStream(filePath);
   workbook.write(stream);
   stream.close();
   addressList = null;
   validation = null;
}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值