Excel導入

  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     }
相關文章
相關標籤/搜索