Excel导入

Posted Eee_xiang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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     }

 

以上是关于Excel导入的主要内容,如果未能解决你的问题,请参考以下文章

将excel中数据用JAVA代码导入到oracle中,遇到日期类型应该怎么处理!?

访问 VBA 代码以导入 excel 文件

C#导入导出数据到Excel的通用类代码

ASP.NET中如何把Excel的数据导入到数据库中,最好给详细的代码和注释

jsp导入和导出excel的代码(jsp连接excel的方法)

求一个能把EXCEL批量导入SQL数据库的ASP程序代码!!!