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 ...
随机推荐
- HTML基础之HTML标签-html header(meta,title) html body(p,br,h,form,div,span,input,lable)
摘自:http://www.imdsx.cn/index.php/2017/07/27/html0/ 一.HTML标签 <!DOCTYPE html> <!--标准的html规则,类 ...
- word简单优化--提高效率
1.文件 ---选项---校对(去掉下面这些项) 2.点击自动更正,去掉如下 3.文件--选项--保存
- 【论文阅读】Deep Adversarial Subspace Clustering
导读: 本文为CVPR2018论文<Deep Adversarial Subspace Clustering>的阅读总结.目的是做聚类,方法是DASC=DSC(Deep Subspace ...
- 转换编码utf-8
用这个enca -x utf-8 * 或者是 filename,还有别的方法,参见:https://blog.csdn.net/a280606790/article/details/8504133 我 ...
- 从零开始一起学习SLAM | 理解图优化,一步步带你看懂g2o代码
首发于公众号:计算机视觉life 旗下知识星球「从零开始学习SLAM」 这可能是最清晰讲解g2o代码框架的文章 理解图优化,一步步带你看懂g2o框架 小白:师兄师兄,最近我在看SLAM的优化算法,有种 ...
- cocos2d-x JS 定时器暂停方法
this.scheduleOnce(function(){ this.addChild(Menugobtn);//要暂停执行的代码 }, 10);
- mysql 游标嵌套
BEGIN -- 开始存储过程 declare my_ID varchar(32); -- 线路iddeclare my_SpecialLineName varchar(50); -- 线路名称 de ...
- Spark生态以及原理
spark 生态及运行原理 Spark 特点 运行速度快 => Spark拥有DAG执行引擎,支持在内存中对数据进行迭代计算.官方提供的数据表明,如果数据由磁盘读取,速度是Hadoop MapR ...
- css3动态计算元素的高度及宽度
1.px 像素,我们在网页布局中一般都是用px. 2.百分比 百分比一般宽泛的讲是相对于父元素,自适应网页布局越来越多,百分比也经常用到了 3.Viewport 当已知一个div的高度 ...
- vue的一些感想
如今vue2.0是主流,但是它的路由确实直接从1.0过来的,其中包括组件包括全局组件和局部组件,写好组件之后,我们就需要 使用路由,将组件关联起来,关联起来之后,然后我们才可以将组件的内容通过hash ...