一、只有18位的身份证号码

如:

身份证号

330682199302264000

41120019890823729X

231081199002256839

131101198203154666

360300198205270958

11010519491231002X

计算步骤:

step1:提取生日字符串:

=MID(A2,7,8)

,生日从第七位开始,共八个数。

step2:这一步,可以分为两种方法:


方法一:采用分列工具

1.将公式生成的日期复制:

2.在同一列粘贴成“值”的格式:

3.选择需要进行分列的生日:

4.在“数据”中点击“分列”:

5.按如下步骤进行:

勾选“固定宽度”

在生日年份和月份以及月份和日期之间对应的红色区域中点击,建立分割线:

在第三步勾选“日期”,点击完成:

该字符串被分解成三个独立的单元:

6.在新的一列中输入公式

=DATE(B2,C2,D2)

——之前的年月日,完成。

就可以得到身份证提取的生日了。


方法二:使用公式

1.将字符串以0-00-00的格式显示:

=TEXT(B2,"0-00-00")

一步完成。


二、只有15位身份证号码

这种情况基本不会出现的,即使出现了,专门立栏也没必要,直接进入下一节。


三、15位身份证号码和18位身份证号码并存

例如:

step1:提取生日字符串:

18位身份证,从第7位开始,提取8个数字;

15位身份证,从第7位开始,提取6个数字。

因此需要使用IF函数,根据身份证号的长度,选择提取位数的长度:

=MID(A2,7,IF(LEN(A2)=18,8,6))

step2:将提取的字符串,以特定格式表示:

=TEXT(MID(A2,7,IF(LEN(A2)=18,8,6)),"0-00-00")

step3:转为时间序列

现在需要解决这样一个问题,就是15位身份证日期显示错误的问题:

解决方法是,通过乘法将它转变为时间序列:

=1*TEXT(MID(A2,7,IF(LEN(A2)=18,8,6)),"0-00-00")

step3:最后转为日期

=TEXT(1*TEXT(MID(A2,7,IF(LEN(A2)=18,8,6)),"0-00-00"),"yyyy-mm-dd")

之前的TEXT函数不能转为”yyyy-mm-dd”的原因,是因为年份前两位缺少,现在可以直接通过时间序列将其转为日期了。

注:yyyy-mm-dd是日期格式的一种,而0-00-00只是文本一种显示格式。


四、最后的Plan B

经过计算,通过IF函数确定选取的字符数,与LEN(A2)/2.2的结果是一致的。

=TEXT(1*TEXT(MID(A2,7,LEN(A2)/2.2),"0-00-00"),"YYYY-MM-DD")


五、计算年龄

作为一个拓展,可以通过日期计算他/她的年龄。

=YEAR(TODAY())-YEAR(C2)

函数TODAY()不需要参数,直接返回今天的日期,如2008-08-08。

函数YEAR返回日期的年份。

Excel—身份证生日提取的更多相关文章

  1. 用python库openpyxl操作excel,从源excel表中提取信息复制到目标excel表中

    现代生活中,我们很难不与excel表打交道,excel表有着易学易用的优点,只是当表中数据量很大,我们又需要从其他表册中复制粘贴一些数据(比如身份证号)的时候,我们会越来越倦怠,毕竟我们不是机器,没法 ...

  2. Excel日期格式提取year

    Excel日期格式提取year =TEXT(YEAR(C2),"0000")

  3. Excel自动从身份证中提取生日、性别、年龄

    现在学生的身份证号已经全部都是18位的新一代身份证了,里面的数字都是有规律的.前6位数字是户籍所在地的代码,7-14位就是出生日期.第17位“2”代表的是性别,偶数为女性,奇数为男性.我们要做的就是把 ...

  4. 从身份证号提取生日并更新到生日字段中的SQL语句

    1:根据身份证号 更新 生日字段 SQL update 学生信息 ,)+,)+,) 2:根据身份证号 更新 性别字段 SQL update 学生信息 set 性别='男' and substring( ...

  5. Excel身份证验证,身份证校验公式

    =IF(LEN(Q4)=0,"空",IF(LEN(Q4)=15,"老号",IF(LEN(Q4)<>18,"位数不对",IF(CH ...

  6. excel支持正则表达式提取字符函数(支持RegExp捕获分组)

    一.要让excel脚本支持Microsoft VBScript Regular Expressions 5.5 ,按快捷键alt+F11,出现下图界面,操作如图示: 二.添加VBA代码: 代码添加完毕 ...

  7. 关于excel导入手机号提取时被自动加上多余空万国码的问题

    //去除excel粘贴自动加上的空万国码“\U202d” "U202c" //去除excel粘贴自动加上的空万国码“\U202d” "U202c" String ...

  8. node 读取超大Excel 文件,提取数据

    之前是用 node-xlsx 来处理excel文件,主要是读取数据或者根据数据生成excel文件.不过,node-xlsx 似乎无法处理超大的excel(100MB以上),例如: var xlsx = ...

  9. python解析excel中图片+提取图片

    解析表格是常用的技术.但是有些表各里面有图片怎么办?我想获得表格里面的图片,值得注意的是,图片没有位置信息,所以最好给图片进行编号,编号代表位置. 下面附上提取表格里面图片的代码.只要输出表格地址,和 ...

随机推荐

  1. Oracle存储过程基本语法介绍

    Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR RE ...

  2. 2016.10.29 NOIP模拟赛 PM 考试整理

    300分的题,只得了第三题的100分. 题目+数据:链接:http://pan.baidu.com/s/1o7P4YXs 密码:4how T1:这道题目存在着诸多的问题: 1.开始的序列是无法消除的( ...

  3. [备份]破解Xamarin

    [转]试用了一阵子Mono For Android,今天到期了,,囊中羞涩,只好破解. 说是要在vs2013的英文界面下运行破解包,不知道是真是假,下载并安装了一个. 然后又下载了破解包.是个名为xa ...

  4. python-异常处理

    一.异常 异常是什么? 就是影响程序正常执行的事件,异常在程序执行的过程中发生,脚本发生异常时,我们需要捕获它,否则程序就会终止. 异常处理: 1.捕获异常:try:...except ..... w ...

  5. 如何设置ASP.NET页面的运行超时时间

    全局超时时间 服务器上如果有多个网站,希望统一设置一下超时时间,则需要设置 Machine.config 文件中的 ExecutionTimeout 属性值.Machine.config 文件位于 % ...

  6. JS组件系列——使用HTML标签的data属性初始化JS组件

    前言:最近使用bootstrap组件的时候发现一个易用性问题,很多简单的组件初始化都需要在JS里面写很多的初始化代码,比如一个简单的select标签,因为仅仅只是需要从后台获取数据填充到option里 ...

  7. 51Nod-1279 扔盘子

    51Nod:  http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1279 1279 扔盘子 题目来源: Codility 基 ...

  8. time & datetime

    时间相关的操作,时间有三种表示方式: 时间戳               1970年1月1日之后的秒,即:time.time() 格式化的字符串    2014-11-11 11:11,    即:t ...

  9. Lua和C++交互详细总结

    转自:http://cn.cocos2d-x.org/tutorial/show?id=1474 一.Lua堆栈 要理解Lua和C++交互,首先要理解Lua堆栈. 简单来说,Lua和C/C++语言通信 ...

  10. ansible的SSH连接问题

    问题描述: 在ansible安装完毕后一般需要以SSH的方式连接到需要进行管理的目标主机,一开始遇到了如下问题: # ansible -m ping all 10.200.xx.xx | UNREAC ...