List of usage examples for org.apache.poi.xssf.usermodel XSSFDataValidationConstraint XSSFDataValidationConstraint
public XSSFDataValidationConstraint(String[] explicitListOfValues)
From source file:com.heimaide.server.common.utils.excel.ExportExcel.java
License:Open Source License
/** * ?//from w ww . j a v a 2 s .c om * * @param row * * @param column * ? * @param val * * @param align * ??1?23?? * @return ? */ public Cell addCell(Row row, int column, Object val, int align, Class<?> fieldType, String[] constraintValue) { Cell cell = row.createCell(column); CellStyle style = styles.get("data" + (align >= 1 && align <= 3 ? align : "")); try { if (val == null) { cell.setCellValue(""); } else if (val instanceof String) { cell.setCellValue((String) val); } else if (val instanceof Integer) { cell.setCellValue((Integer) val); } else if (val instanceof Long) { cell.setCellValue((Long) val); } else if (val instanceof Double) { cell.setCellValue((Double) val); } else if (val instanceof Float) { cell.setCellValue((Float) val); } else if (val instanceof Date) { DataFormat format = wb.createDataFormat(); style.setDataFormat(format.getFormat("yyyy-MM-dd")); cell.setCellValue((Date) val); } else { if (fieldType != Class.class) { cell.setCellValue((String) fieldType.getMethod("setValue", Object.class).invoke(null, val)); } else { cell.setCellValue((String) Class .forName(this.getClass().getName().replaceAll(this.getClass().getSimpleName(), "fieldtype." + val.getClass().getSimpleName() + "Type")) .getMethod("setValue", Object.class).invoke(null, val)); } } if (constraintValue.length > 0) { // ? // ??? CellRangeAddressList regions = new CellRangeAddressList(row.getRowNum(), row.getRowNum(), column, column); // ? XSSFDataValidationConstraint constraint = new XSSFDataValidationConstraint(constraintValue); DataValidationHelper help = sheet.getDataValidationHelper(); // DataValidation validation = help.createValidation(constraint, regions); validation.createErrorBox("", ""); validation.setShowErrorBox(true); // sheet sheet.addValidationData(validation); } } catch (Exception ex) { log.info("Set cell value [" + row.getRowNum() + "," + column + "] error: " + ex.toString()); cell.setCellValue(val.toString()); } cell.setCellStyle(style); return cell; }