EXCEL根据身份证号计算出生日期和截止某日的年龄

在 Excel 中,可以通过身份证号(18 位)自动提取出生日期 并计算截至指定日期(如 2026-01-16)的年龄 。以下是具体公式(假设身份证号在 A2 单元格):

步骤 1:提取出生日期

中国居民身份证第 7 到第 14 位是出生日期(格式:YYYYMMDD)。

B2 单元格输入以下公式,得到标准日期格式:

=DATE(MID(A2,7,4),MID(A2,11,2),MID(A2,13,2))

建议:将 B 列单元格格式设置为「短日期」或「yyyy-mm-dd」以便阅读。

步骤 2:计算截至 2026-01-16 的年龄

C2 单元格输入以下公式:

=DATEDIF(B2, DATE(2026,1,16), "y")

说明:

DATEDIF 是 Excel 隐藏但有效的函数,用于计算两个日期之间的完整年数。

"y" 表示返回整年数(不满一年不计),符合常规年龄计算逻辑。

示例:

出生日期:1990-03-07 → 截至 2026-01-16 未满 36 岁 → 年龄 = 35

出生日期:1990-01-10 → 已满 36 岁 → 年龄 = 36

完整示例

A(身份证号) B(出生日期) C(截至2026-01-16的年龄)
110101199003071234 1990/3/7 35
110101199001101234 1990/1/10 36
20200101123456789X 2020/1/1 6

注意事项

  1. 身份证必须是 18 位 ,且第 7--14 位为有效日期(如不能是 19901340)。
  2. 如果身份证号以 0 开头 (如某些地区),请确保单元格格式为「文本」,否则 Excel 会自动去掉前导零导致错误。
    • 输入前先设置单元格格式为「文本」,或在身份证前加单引号:'010123199001011234
  3. DATEDIF 在 Excel 中不会自动提示,但可以直接使用。

合并为一个公式(不显示出生日期),如果你只需要年龄,可在 C2 直接用:

=DATEDIF(DATE(MID(A2,7,4),MID(A2,11,2),MID(A2,13,2)), DATE(2026,1,16), "y")

相关推荐
SunnyDays10113 小时前
Python操作Excel批注:从基础添加到高级自定义的完整指南
开发语言·python·excel
Eiceblue5 小时前
Python 操作 Excel:数据分组、分类汇总与取消分组全解
开发语言·python·excel
城数派6 小时前
2026年500米分辨率DEM地形数据(全球/全国/分省/分市)
数据库·arcgis·信息可视化·数据分析·excel
SunnyDays10117 小时前
Python 操作 Excel 超链接:添加网页、文件、工作表和图片链接
python·excel
专注VB编程开发20年9 小时前
我制作excel工作簿的选项卡,发给deep seek, 昨天修改了一天
前端·vue.js·excel
星越华夏1 天前
python办公自动化,csv文件/excel文件差集合并
开发语言·python·excel
开开心心就好1 天前
180套模板的图片艺术拼接实用工具
linux·服务器·网络·spring·智能手机·maven·excel
仰望.1 天前
vxe-table 导出 Excel 进阶教程:自定义样式与高级功能
前端·javascript·vue.js·excel·vxe-table·vxe-ui
Access开发易登软件2 天前
Access 和 SQLite,根本不在一个赛道上
java·jvm·数据库·sqlite·excel·vba·access开发
biuyyyxxx2 天前
Excel常见异常
excel