个人用到的

           String birthdayVal = null;
                                
                                        switch (cell_2.getCellTypeEnum()) {
                                            case STRING:  
                                                birthdayVal = cell_2.getRichStringCellValue().getString();  
                                                break;  
                                            case NUMERIC:  
                                                if("General".equals(cell_2.getCellStyle().getDataFormatString())){  
                                                    birthdayVal =DateToStr(HSSFDateUtil.getJavaDate(cell_2.getNumericCellValue()));  
                                                }else if("m/d/yy".equals(cell_2.getCellStyle().getDataFormatString())){  
                                                    birthdayVal = DateToStr(cell_2.getDateCellValue());  
                                                }else{  
                                                    birthdayVal = DateToStr(HSSFDateUtil.getJavaDate(cell_2.getNumericCellValue()));  
                                                }  
                                                break;  
                                            default:  
                                                x = i+1;
                                                throw new AWSForbiddenException("导入文件的第["+x+"]行的[出生年月]的格式有问题,请检查!",null);
                                           }

/**
    * 日期转换成字符串
    */
    public static String DateToStr(Date date) {
       java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyy-MM-dd");
       String str = format.format(date);
       return str;
    }

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------

poi3.5之前的版本

switch (cell.getCellType()) {
    case HSSFCell.CELL_TYPE_NUMERIC: // 数字
        //如果为时间格式的内容
        if (HSSFDateUtil.isCellDateFormatted(cell)) {      
           //注:format格式 yyyy-MM-dd hh:mm:ss 中小时为12小时制,若要24小时制,则把小h变为H即可,yyyy-MM-dd HH:mm:ss
           SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");  
           value=sdf.format(HSSFDateUtil.getJavaDate(cell.
           getNumericCellValue())).toString();                                 
             break;
         } else {
             value = new DecimalFormat("0").format(cell.getNumericCellValue());
         }
        break;
    case HSSFCell.CELL_TYPE_STRING: // 字符串
        value = cell.getStringCellValue();
        break;
    case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
        value = cell.getBooleanCellValue() + "";
        break;
    case HSSFCell.CELL_TYPE_FORMULA: // 公式
        value = cell.getCellFormula() + "";
        break;
    case HSSFCell.CELL_TYPE_BLANK: // 空值
        value = "";
        break;
    case HSSFCell.CELL_TYPE_ERROR: // 故障
        value = "非法字符";
        break;
    default:
        value = "未知类型";
        break;
}

poi3.5以后版本

switch (cell.getCellTypeEnum()) {  
    case STRING:  
        value = cell.getRichStringCellValue().getString();  
        break;  
    case NUMERIC:  
        if("General".equals(cell.getCellStyle().getDataFormatString())){  
            value = df.format(cell.getNumericCellValue());  
        }else if("m/d/yy".equals(cell.getCellStyle().getDataFormatString())){  
            value = sdf.format(cell.getDateCellValue());  
        }else{  
            value = df2.format(cell.getNumericCellValue());  
        }  
        break;  
    case BOOLEAN:  
        value = cell.getBooleanCellValue();  
        break;  
    case BLANK:  
        value = "";  
        break;  
    default:  
        value = cell.toString();  
        break;  
    }

POI Excel 单元格内容类型判断并取值的更多相关文章

  1. poi 升级至4.x 的问题总结(POI Excel 单元格内容类型判断并取值)

    POI Excel 单元格内容类型判断并取值 以前用 cell.getCachedFormulaResultType() 得到 type 升级到4后获取不到了 换为:cell.getCellType( ...

  2. Excel单元格内容太多会覆盖遮住下一单元格范围

    Excel单元格内容太多会覆盖遮住下一单元格范围分步阅读 Excel中的单元格内容,有着不同的对齐方式.用户可根据自己的需求,在处理数据的时候,自行设置所需要的对齐方式. 当您在处理数据的时候,如果设 ...

  3. excel 单元格内容太多,替换有问题

    excel 单元格内容太多,替换有问题

  4. Excel单元格内容拆分、合并

    例:如何将EXCEL单元格A1中的“1-2-1”,在B1.C1.D1单元格中分别显示”1“.”2“.”1“.方法一: 在B1中输入“=mid(A1,1,1)”在C1中输入“=mid(AI,3,1)”在 ...

  5. excel单元格内容拆分

    这几天在整理数据,但是数据都在表格的一个单元格中,看起来很不方法,所以在网上找到excel单元格内如拆分的方法,并亲测有效 介绍2种拆分的方法 方法一: (1)在B1输入公式=right(text,[ ...

  6. 使用poi导出Excel,并设定单元格内容类型,抛出异常

    本例子使用的是HSSF,为Excel2003提供处理方案. 设定为输入类型为数值 import org.apache.poi.hssf.usermodel.DVConstraint; import o ...

  7. java POI Excel 单元格样式

    正如Html需要CSS一样,我们的POI生成的Excel同样需要样式才能更完美的表现我们的数据.下面还是从简单的例子出发,学习和了解POI的样式设计. 一.我的位置. 1 package com.my ...

  8. Excel单元格内容批量加前缀

    比如83190001在A1单元格,要在A列单元内容前面批量加0,在B1输入公式="0"&A1然后向下复制再把B列复制的结果再复制一下:然后到新的一列粘贴,在“粘贴选项”中选 ...

  9. excel单元格内容合并

    这几天在整理数据,有时候数据都在表格的不同单元格中,想把两格内容合并为一格,于是验证了两种方法 方法一: (1)在B1输入公式=A1&B1 (2)做完第一步后,选中B1后,鼠标移到单元格右下出 ...

随机推荐

  1. Spring MVC数据绑定入门总结

    1.基本类型 基本类型参数不可为空 正例:http://localhost:8080/demo/he?id=2 反例:http://localhost:8080/demo/he?id=(报400错误) ...

  2. .net排坑篇:负载均衡域名转发的背后

    背景 昨天因客户私有部署问题,需要到客户公司去排查问题. 他们是一家外企,各种权限需要提前申请(最大的坑).他们之前部署的一般为单域名,很少部署互联网类型多个域名的情形(第二个坑).这次私有部署总计使 ...

  3. 52abp框架asp.net core & Angular快速开发实战视频教程

    课程标题 52abp框架asp.net core & Angular全栈开发实战视频课程 课程简介 从零开始学 52ABP企业开发框架,企业项目是如何开发和技术选型,代码如何管理,团队协同开发 ...

  4. BFC 原理

    BFC:Block-level box           +   Forating  +           Context; ------->块元素          决定其子元素如何定位, ...

  5. Joyride (spaf)

    题目链接:https://codeforces.com/gym/101873/problem/C spaf的复杂度有点迷,按道理来说,一个简单的spaf在这题的复杂度是1e9,所以不敢写,然后用优先队 ...

  6. Javascript模板引擎handlebars使用

    源地址:http://rfyiamcool.blog.51cto.com/1030776/1278620 代码示例: <!DOCTYPE html> <html> <he ...

  7. MongoDB之$

    MongoDB之$ $  保存符合索引条件的下标 db.userinfo.updateOne({ghobby: },{$set:{'ghobby.2': '四'}}) // 将userinfo表中的g ...

  8. 2019省赛训练组队赛3.26周二---FJUT 2016

    A.Minimum’s Revenge There is a graph of n vertices which are indexed from 1 to n. For any pair of di ...

  9. 牛客OI周赛8-普及组

    https://ac.nowcoder.com/acm/contest/543#question A. 代码: #include <bits/stdc++.h> using namespa ...

  10. 使用 Drools 和 JPA & Drools show case in docker hub

    使用 Drools 和 JPA 实现持续的实时数据分析https://www.ibm.com/developerworks/cn/java/j-drools5/index.html Drools - ...