java poi excel操作 下拉菜单 及数据有效性
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操作 下拉菜单 及数据有效性的更多相关文章
- 『心善渊』Selenium3.0基础 — 13、Selenium操作下拉菜单
目录 1.使用Selenium中的Select类来处理下拉菜单(推荐) 2.下拉菜单对象的其他操作(了解) 3.通过元素二次定位方式操作下拉菜单(重点) (1)了解元素二次定位 (2)示例: 页面中的 ...
- excel设置下拉菜单,并且不同值会显示不同颜色
工作中常常要用的excel,每次都会有新的需求,然后不会,然后百度,然后过段时间可能就又忘了,于是就想说,自己记录下来~~~因为自己用的都是2010,其实哪个版本都差不多,都是应该可以找到相应的按钮滴 ...
- Excel添加下拉菜单
一.选中需要下拉菜单的单元格 二.数据--数据校验 三 .选择序列,填写来源 四.保存
- Python+Selenium笔记(八):操作下拉菜单
(一) Select类 Select类是selenium的一个特定的类,用来与下拉菜单和列表交互. 下拉菜单和列表是通过HTML的<select> 元素实现的.选择项是通过<sele ...
- Excel设置下拉菜单并隐藏下拉菜单来源单元格内容
一.问题来源 做实验室的进展统计表,老师让加上开始时间和完成时间,时间格式:周几_上午(下午.晚上). 这样就可以了做下拉菜单,方便填写,而且格式统一,方便查看. 二.解决办法 2.1 下来菜单 红框 ...
- 使用EXCEL设置“下拉菜单”选项功能
原创作品.出自 "深蓝的blog" 博客.欢迎转载.转载时请务必注明出处,否则有权追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlo ...
- java poi excel操作 把第一列放到最后去
@Override public void adjustExcleColumnPosition(String filePath,int col) throws Exception{ File file ...
- Excel 二级下拉菜单
http://jingyan.baidu.com/article/cd4c2979f31967756f6e6066.html http://hi.baidu.com/chenshake/item/e1 ...
- Selenium下拉菜单(Select)的操作-----Selenium快速入门(五)
对于一般元素的操作,我们只要掌握本系列的第二,三章即可大致足够.对于下拉菜单(Select)的操作,Selenium有专门的类Select进行处理.文档地址为:http://seleniumhq.gi ...
随机推荐
- https://stackoverflow.com/questions/10423781/sql-data-range-min-max-category
select phone,count(order_id) as c from table_recordgroup by phoneorder by c desc SELECT CASEWHEN (ag ...
- 转:解决tomcat服务器跨域问题
原文地址: 解决tomcat服务器跨域请求问题 注:还未测试 在tomcat 的web.xml 配置文件中加入如下配置过滤器 (如web.xml中有多个filter时要把下面配置放在最前端) < ...
- Mac 启动或者禁用翻盖自动开关机
从 2016 新款 MacBook Pro 起,预设打开笔电上盖或连接电源供应器时,电脑就会自动开机而且开机时没有启动声,本文教你如何将这些东西调整回原本的样子. 以下指令都是通过「应用程序」→「终端 ...
- angular--获取时间方法services
写了一些公用方法获取自然周.传入开始和结束日期,获取中间全部日期等方法 .service('DateServices', [function () { // 获取某年自然周的方法 (如果是当年,只返回 ...
- vivi.c框架
内核文档: V4L2-framework.txt UVC:usb video controll UVC驱动框架: system call: open read write -------------- ...
- git中设置http代理和取消http代理
设置http代理 git config --global https.proxy https://127.0.0.1:1080 取消http代理git config --global --unset ...
- Thinkphp----------Thinkphp3.2的目录结构介绍
ThinkPHP框架目录结构\index.php 入口文件\Application 应用目录\Public 资源文件目录\ThinkPHP 框架核心目录 ...
- linux----------linux的scp命令介绍
1.scp是有Security的文件copy,基于ssh登录. 命令基本格式: scp [OPTIONS] file_source file_target OPTIONS: -v 和大多数 linux ...
- Openstack-Namespaces
介绍OpenStack neutron使用Linux网络命名空间来避免物理网络和虚拟网络间的冲突,或者不同虚拟网络间的冲突. 网络命名空间就是一个独立的网络协议栈,它有自己的网络接口,路由,以及防火墙 ...
- ACM-ICPC 2018 南京赛区网络预赛 Solution
A. An Olympian Math Problem cout << n - 1 << endl; #include <bits/stdc++.h> using ...