1 public static Collection importExcelByIs(InputStream inputstream, 2 List<CgFormFieldEntity> lists) { 3 Map<String, CgFormFieldEntity> fieldMap = ConvertDate(lists); 4 //返回的數據類型 5 List<Map<String, Object>> tObject = new ArrayList<Map<String,Object>>(); 6 try { 7 // 將傳入的File構造爲FileInputStream; 8 // // 獲得工做表 9 HSSFWorkbook book = new HSSFWorkbook(inputstream); 10 // // 獲得第一頁 11 HSSFSheet sheet = book.getSheetAt(0); 12 // // 獲得第一面的全部行 13 Iterator<Row> row = sheet.rowIterator(); 14 // 獲得第一行,也就是標題行 15 Row title = row.next(); 16 // 獲得第一行的全部列 17 Iterator<Cell> cellTitle = title.cellIterator(); 18 // 將標題的文字內容放入到一個map中。 19 Map titlemap = new HashMap(); 20 // 從標題第一列開始 21 int i = 0; 22 // 循環標題全部的列 23 while (cellTitle.hasNext()) { 24 Cell cell = cellTitle.next(); 25 String value = cell.getStringCellValue(); 26 if (fieldMap.get(value)==null) { 27 throw new BusinessException("導入數據excel列名有不能識別的列"); 28 } 29 titlemap.put(i, value); 30 i = i + 1; 31 } 32 // 用來格式化日期的DateFormat 33 Map<String, Object> retMap=null; 34 while (row.hasNext()) { 35 retMap= new HashMap<String, Object>(); 36 // 標題下的第一行 37 Row rown = row.next(); 38 // 行的全部列 39 Iterator<Cell> cellbody = rown.cellIterator(); 40 int k = 0; 41 // 遍歷一行的列 42 while (cellbody.hasNext()) { 43 Cell cell = cellbody.next(); 44 // 這裏獲得此列的對應的標題 45 String titleString = (String) titlemap.get(k); 46 if (fieldMap.containsKey(titleString)) { 47 retMap.put(fieldMap.get(titleString).getFieldName(), getCellValueString(cell)); 48 } 49 // 下一列 50 k = k + 1; 51 } 52 tObject.add(retMap); 53 } 54 } catch (Exception e) { 55 e.printStackTrace(); 56 return null; 57 } 58 return tObject; 59 } 60 //TODO huiyong excel日期格式處理默認如此,須要從數據庫或者配置文件讀取 61 public final static DateFormat DEFAULT_DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd"); 62 /** 63 * 獲得某個格子的值 已經對過期方法進行更新 64 * 65 * @param cell 66 * 格子對象 67 * @return 格子的值 68 */ 69 public static String getCellValueString(Cell cell) { 70 if (cell == null) { 71 return null; 72 } 73 // 時間對象 特殊處理 74 int dataFormat = cell.getCellStyle().getDataFormat(); 75 76 if (dataFormat == 14 || dataFormat == 178 || dataFormat == 180 || dataFormat == 181 77 || dataFormat == 182) { 78 return getDateValue(cell); 79 } 80 String value = null; 81 switch (cell.getCellType()) { 82 case Cell.CELL_TYPE_NUMERIC : 83 value = new DecimalFormat("0.##########").format(cell.getNumericCellValue()); 84 break; 85 case Cell.CELL_TYPE_STRING : 86 // value = cell.getStringCellValue(); 87 value = cell.getRichStringCellValue().toString(); 88 break; 89 case Cell.CELL_TYPE_FORMULA : 90 value = String.valueOf(cell.getCellFormula()); 91 break; 92 case Cell.CELL_TYPE_BLANK : 93 // value = String.valueOf(cell.getStringCellValue()); 94 value = String.valueOf(cell.getRichStringCellValue().toString()); 95 break; 96 case Cell.CELL_TYPE_BOOLEAN : 97 value = String.valueOf(cell.getBooleanCellValue()); 98 break; 99 case Cell.CELL_TYPE_ERROR : 100 value = String.valueOf(cell.getErrorCellValue()); 101 break; 102 } 103 return value; 104 } 105 /** 106 * 返回時間內的特殊時間格式 OFFICE2003 107 * @param cell 108 * @return 109 */ 110 private static String getDateValue(Cell cell){ 111 return DEFAULT_DATE_FORMAT.format(cell.getDateCellValue()); 112 } 113 /** 114 * 數據處理 115 */ 116 private static Map<String,CgFormFieldEntity> ConvertDate(List<CgFormFieldEntity> lists){ 117 Map<String,CgFormFieldEntity> maps = new HashMap<String, CgFormFieldEntity>(); 118 119 for (CgFormFieldEntity cgFormFieldEntity : lists) { 120 maps.put(cgFormFieldEntity.getContent(), cgFormFieldEntity); 121 } 122 return maps; 123 }