POI写入Excel下拉框[Select选项]
来源:互联网 发布:北京网络职业学院 八维 编辑:程序博客网 时间:2024/06/05 14:53
记录部分方法, 操作POI
POI version
1.首先根据路径读取Excel模板
2.获取到workbook后,设置哪些行列是下拉框[Select下拉],并设置数据
3.由于workbook读取后,在保存原来excel会出现错误,这个是poi的一个小bug吧,官方
也没有看到怎么解释,只能修改后, 重新命名保存一个新的Excel模板
POI version
<poi.version>3.10-FINAL</poi.version><dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>${poi.version}</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>${poi.version}</version> </dependency>
1.首先根据路径读取Excel模板
/** * 读取服务器上面的上传的excel文件 * * @param path * @return */public static Workbook readWorkBook(String path) {Workbook wb = null;try {wb = WorkbookFactory.create(new File(path));} catch (InvalidFormatException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}return wb;}
2.获取到workbook后,设置哪些行列是下拉框[Select下拉],并设置数据
public String rewriteExcelTempAtEmp(String instance, String path, String upload) {//读取默认模板Excel文件Workbook workbook = ExcelUtils.readWorkBook(path);Sheet sheet = workbook.getSheetAt(0);DataValidationHelper helper = sheet.getDataValidationHelper(); //CellRangeAddressList(firstRow, lastRow, firstCol, lastCol)设置行列范围CellRangeAddressList addressList = new CellRangeAddressList(3, 500, 17, 17);//设置下拉框数据String[]pos = posStatusName(instance);DataValidationConstraint constraint = helper.createExplicitListConstraint(pos); DataValidation dataValidation = helper.createValidation(constraint, addressList);//处理Excel兼容性问题if(dataValidation instanceof XSSFDataValidation) {dataValidation.setSuppressDropDownArrow(true);dataValidation.setShowErrorBox(true);}else {dataValidation.setSuppressDropDownArrow(false);}sheet.addValidationData(dataValidation);String fileName = StringUtils.substringAfterLast(path, "/"); String newPath = upload+ExcelUtils.getRename(fileName, false); //由于POI打开读取文件后再保存时bug问题, 只能重新定义一个新的Excel写入数据 ExcelUtils.createExcel(workbook, newPath); return newPath;}
3.由于workbook读取后,在保存原来excel会出现错误,这个是poi的一个小bug吧,官方
也没有看到怎么解释,只能修改后, 重新命名保存一个新的Excel模板
/** * 根据路径创建Excel * @author lance * 2014年8月13日 下午4:06:10 * @param workbook * @param path */public static void createExcel(Workbook workbook, String path) { FileOutputStream fileOut = null;try {fileOut = new FileOutputStream(path);workbook.write(fileOut);} catch (Exception e) {logger.error("Error create excel: ", e.getMessage());} finally {try {if(fileOut != null) {fileOut.close();}} catch (IOException e) {e.printStackTrace();}}}
0 0
- POI写入Excel下拉框[Select选项]
- poi导出excel用隐藏sheet方式封装下拉框(下拉选项值多的情况)
- 用POI写入Excel
- poi 写入excel
- Java POI 写入Excel
- Java POI 写入Excel
- Java POI 写入Excel
- POI实现Excel写入
- Java POI 写入Excel
- poi 读取写入excel
- 下拉框select标记清空选项
- poi实现excel下拉框级联
- POI操作Excel,创建下拉框
- poi XSSFWorkbook实现excel中的下拉框
- java利用poi写入Excel
- POI读取和写入Excel
- POI操作Excel,读取,写入
- 利用poi组件写入excel
- jquery实现图片轮番效果(一)
- Android Activity 切屏处理
- Android调用打电话(Call Phone)
- Android自定义ListFragment 显示
- 【数据结构】算法8.2 伙伴系统-分配
- POI写入Excel下拉框[Select选项]
- mvn jetty:run内存溢出解决
- Web框架学习篇--Strust1(一) 原理
- 程序员心里的侥幸
- 举例让抽象具体化-面试题22-栈的压入、弹出序列
- redis 配置‘随手记
- 记录springmvc+ueditor1.4.3上传附件问题
- spring集成ActiveMQ, 消息提供者
- hdu1281棋盘游戏