zoukankan      html  css  js  c++  java
  • Excel提取身份证出生日期②

    问题场景


    • 从user表中的身份信息中提取用户的出生日期;

    • 以下方法也可适用于提取其他数据,不仅是身份证信息;

    • 以下图中数据都为测试数据,不具备真实性!

    场景一


    • user表中的18位身份证,提取出生日期。

      • 不考虑15位身份证号,场景二会提及15位时的情况。

    img

    目标


    • 提取身份证信息列所有用户的出生日期。

    解决方案一


    用Ctrl+E提取填充。

    • 第一步:将D2单元格【身份证信息列】的7-14位(出生日期)复制到F2单元格。

      • 18位身份证信息的7-14位是出生日期。

    img

    • 第二步:同时按Ctrl+E填充,最后结果。

      • 注意:这种方式提取出的不是日期格式。

    img

    解决方案二


    用mid()函数和连接符号“&”提取

    • 函数解释
    =MID(text, start_num, num_chars)
    #从一个字符串中截取出指定数量的字符
    #text被截取的字符,start_num从左起第几位开始,num_chars截取的长度是多少
    
    • 第一步:在F2单元格英文状态下输入:=MID(D2,7,4)&"-"&MID(D2,11,2)&"-"&MID(D2,13,2)。

      • 公式解释:MID(D2,7,4)、MID(D2,11,2)、MID(D2,13,2)分别截取的出生年、出生月、出生日,再用&符号将年月日用“-”连接起来(用"/"连接年月日也可以)。

    img

    • 第二步:鼠标移到F2单元格的右下角,出现实心的黑色【+】号,双击填充此公式。

    img

    • 第三步:最后结果。

    img

    解决方案三


    用data()函数和mid()函数提取。

    • 函数解释
    =DATE(year,month,day)
    #将结果将设为日期格式,且year,month,day三个参数为年、月、日参数
    #MID函数解释看上面方案二
    
    • 第一步:在F2单元格英文状态下输入:=DATE(MID(D2,7,4),MID(D2,11,2),MID(D2,13,2))。

      • 公式解释:MID(D2,7,4)把D2单元格的数据从第7位开始,截取4位,是出生的年份,对应DATE()函数里的第一个参数:year,另外两个参数同理。

    img

    • 第二步:鼠标移到F2单元格的右下角,出现实心的黑色【+】号,双击填充此公式。

    img

    • 第三步:最后结果为日期格式。

    img

    解决方案四


    用Text()函数和mid()函数提取。

    • 函数解释
    =TEXT(value,format_text)
    #通过格式代码向数字应用格式,进而更改数字的显示方式
    #value为引用的单元格数值,format_text为单元格格式参数代码,这里只用一种"00-00-00",表示日期
    
    • 第一步:在F2单元格英文状态下输入:=TEXT(MID(D2,7,8),"00-00-00")。

      • 公式解释:MID(D2,7,4)把D2单元格的数据从第7位开始,截取8位,是出生的日期,再用text()函数用日期方式显示。

    img

    • 第二步:鼠标移到F2单元格的右下角,出现实心的黑色【+】号,双击填充此公式。

    img

    • 第三步:最后结果。

    img

    场景二


    • user表中的同时存在18位或15位身份证,提取出生日期。

      • 由于15位身份证号出生年只有2位,是7-8位,考虑到千年的因素(1900-1999,2000-2020(至今)),得先确定年份都是19开头还是20开头。假如19开头:
      • 该情况不常见,下面不详细解释函数。

    img

    目标


    • 提取身份证信息列所有用户的出生日期。

    解决方案一


    用Text()、Len()和Mid()函数。

    =TEXT((LEN(D2)=15)*19&MID(D2,7,6+(LEN(D2)=18)*2),"00-00-00")
    
    • 第一步:在F2单元格中输入上述公式,鼠标移到F2单元格的右下角,出现实心的黑色【+】号,双击填充此公式。

    img

    • 第二步:最后结果(红框里的两条数据是特例,根据常识很大可能是20开头的年份)。

    img

    解决方案二


    用IF()、Len()和Mid()函数。

    =IF(LEN(D2)=15,"19"&MID(D2,7,2)&"-"&MID(D2,9,2)&"-"&MID(D2,11,2),MID(D2,7,4)&"-"&MID(D2,11,2)&"-"&MID(D2,13,2))
    
    • 第一步:在F2单元格中输入上述公式,鼠标移到F2单元格的右下角,出现实心的黑色【+】号,双击填充此公式。

    img

    • 第二步:最后结果(红框里的两条数据是特例,根据常识很大可能是20开头的年份)。

    img

    解决方案三


    • len()函数筛选出身份证为15位和18位的,分别提取。

    • 15位提取方法同18位提取方法原理一样。

    总结


    实际业务场景复杂时,如果不能一次性解决问题,可择优使用、或可结合使用,多尝试,办法总比困难多!

  • 相关阅读:
    用心合作
    添加IE右键菜单 以 调用和运行 自己的程序或文件
    VS2005 My.Computer.Registry 对象 操作注册表 简单示例
    项目经理职业生涯
    Visual studio.NET单元测试中Assert类的用法(转载)
    如何正确理解自动化测试?(转载)
    浅析ASP.NET单元测试中的调试(转载)
    软件项目质量管理实战总结(转)
    主题:小公司如何做项目管理(转)
    什么是“极限编程”?(转载)
  • 原文地址:https://www.cnblogs.com/dr-fall/p/13538098.html
Copyright © 2011-2022 走看看