1 private InputStream updateTemplateStyleHSSF(InputStream inputStream,CsCustCon csCustCon) throws IOException, DAOException{
HSSFWorkbook workbook = new HSSFWorkbook(inputStream);
HSSFSheet firstSheet= workbook.getSheetAt(0);
List<String> strList=csConAcceDao.getAcceNameAndNoListByConId(csCustCon);
String[] strs=(String[])strList.toArray(new String[strList.size()]); String secondSheetName="合同附件名称和编号";
HSSFSheet secondSheet= workbook.createSheet(secondSheetName);
if(null!=strs&&strs.length>0){
for(int i=0;i<strs.length;i++){
HSSFRow row=secondSheet.createRow(i);
HSSFCell cell= row.createCell(0);
cell.setCellValue(strs[i]);
}
}
Name name=workbook.createName();
name.setNameName(secondSheetName);
name.setRefersToFormula(secondSheetName+"!$A$1:$A$"+strs.length);
CellRangeAddressList newStyleRange=new CellRangeAddressList(1,65535,0,0);
DVConstraint constraint=DVConstraint.createFormulaListConstraint(secondSheetName);
HSSFDataValidation dataValidation=new HSSFDataValidation(newStyleRange, constraint);
dataValidation.setShowPromptBox(true);
firstSheet.addValidationData(dataValidation); ByteArrayOutputStream out=new ByteArrayOutputStream();
workbook.write(out);
byte[] contents=out.toByteArray();
InputStream newInputStream= new ByteArrayInputStream(contents);
return newInputStream;
}

需求说明:excel 第一页 第一列为下拉菜单 菜单的数据在第二页全部显示出来

如果 在第二页删除了一项 保存后  第一页第一列下拉菜单中 的数据就少一项

List<String> strList=csConAcceDao.getAcceNameAndNoListByConId(csCustCon);

这行代码为 返回下拉菜单中的数据

参数

InputStream inputStream 为 file 对象生成的   file 对象则是 对应的要解析的excel 生成的
 ByteArrayOutputStream out=new ByteArrayOutputStream();
workbook.write(out);
byte[] contents=out.toByteArray();
InputStream newInputStream= new ByteArrayInputStream(contents);
return newInputStream;

这段代码为 excel 更新后   重新保存 excel 文件

另:

HSSFWorkbook  对象 只能处理 2003及以前版本
XSSFWorkbook 对象  处理 2007及以后版本 

java poi excel操作 下拉菜单 及数据有效性的更多相关文章

  1. 『心善渊』Selenium3.0基础 — 13、Selenium操作下拉菜单

    目录 1.使用Selenium中的Select类来处理下拉菜单(推荐) 2.下拉菜单对象的其他操作(了解) 3.通过元素二次定位方式操作下拉菜单(重点) (1)了解元素二次定位 (2)示例: 页面中的 ...

  2. excel设置下拉菜单,并且不同值会显示不同颜色

    工作中常常要用的excel,每次都会有新的需求,然后不会,然后百度,然后过段时间可能就又忘了,于是就想说,自己记录下来~~~因为自己用的都是2010,其实哪个版本都差不多,都是应该可以找到相应的按钮滴 ...

  3. Excel添加下拉菜单

    一.选中需要下拉菜单的单元格 二.数据--数据校验 三 .选择序列,填写来源 四.保存

  4. Python+Selenium笔记(八):操作下拉菜单

    (一) Select类 Select类是selenium的一个特定的类,用来与下拉菜单和列表交互. 下拉菜单和列表是通过HTML的<select> 元素实现的.选择项是通过<sele ...

  5. Excel设置下拉菜单并隐藏下拉菜单来源单元格内容

    一.问题来源 做实验室的进展统计表,老师让加上开始时间和完成时间,时间格式:周几_上午(下午.晚上). 这样就可以了做下拉菜单,方便填写,而且格式统一,方便查看. 二.解决办法 2.1 下来菜单 红框 ...

  6. 使用EXCEL设置“下拉菜单”选项功能

    原创作品.出自 "深蓝的blog" 博客.欢迎转载.转载时请务必注明出处,否则有权追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlo ...

  7. java poi excel操作 把第一列放到最后去

    @Override public void adjustExcleColumnPosition(String filePath,int col) throws Exception{ File file ...

  8. Excel 二级下拉菜单

    http://jingyan.baidu.com/article/cd4c2979f31967756f6e6066.html http://hi.baidu.com/chenshake/item/e1 ...

  9. Selenium下拉菜单(Select)的操作-----Selenium快速入门(五)

    对于一般元素的操作,我们只要掌握本系列的第二,三章即可大致足够.对于下拉菜单(Select)的操作,Selenium有专门的类Select进行处理.文档地址为:http://seleniumhq.gi ...

随机推荐

  1. iOS NSCache缓存类的了解

    前言:   最近面试时,问到了限定并发数的视频下载,当时回答的时通过GCD_barrier 处理,回来想想也可以通过NSCache处理,所以顺便复习一下,这个知识点. 一,关于NSCache说明 说明 ...

  2. Selenium 2(Webdriver)

    如何用webdriver打开一个浏览器,我们常用的浏览器有firefox和IE两种,firefox是selenium支持得比较成熟的浏览器,很多新的特性都会在firefox中体现.但是做页面的测试,启 ...

  3. python采集百度搜索结果带有特定URL的链接

    #coding utf-8 import requests from bs4 import BeautifulSoup as bs import re from Queue import Queue ...

  4. MACD技术的高级应用--MACD与波浪

    在开始分析MACD指标之前,我想我们必须先从思想上认同以下两点,否则本文的研究就没有意义.  1)趋势在一段时间内是可以把握的:  2)每个指标都有有效的时候,没有指标会始终有效.我们就是要搞清楚指标 ...

  5. python中 ImportError: No module XXX的解决办法

    python是通过过使用:sys.path来获取模块的路径的,返回的但是一个list 向python模块路径中加入自己的模块:sys.path.append(os.path.abspath('%s.. ...

  6. java框架之SpringBoot(14)-任务

    使用 maven 创建 SpringBoot 项目,引入 Web 场景启动器. 异步任务 1.编写异步服务类,注册到 IoC 容器: package zze.springboot.task.servi ...

  7. Javascript根据id获取数组对象

    在业务中,列表页跳转详情页时,经常会将Id值传入,然后再根据id值异步获取数据. 假设有服务端的json数据:  <注意,这里的data是指已经从后端获取的json, 而非后端原始的文件> ...

  8. 蓝桥杯近三年初赛题之二(16年b组)

    1. 煤球数目 有一堆煤球,堆成三角棱锥形.具体:第一层放1个,第二层3个(排列成三角形),第三层6个(排列成三角形),第四层10个(排列成三角形),....如果一共有100层,共有多少个煤球? 请填 ...

  9. Select input 两个元素的宽度高度跟设定值不一致的问题

    在做登录框的时候,需要一个select 元素作为账号输入,一个input作为密码输入框.在css 文件中,将这两个元素的position 设置为relative ,并且width 设置为100%.刷新 ...

  10. 2019/4/2 wen 多态、抽象