python 根据生日计算年龄 sqlalchemy根据身份证号计算生日 性别

复制代码
import datetime


def calculate_age(birth_s='20181215'):
    birth_d = datetime.datetime.strptime(birth_s, "%Y%m%d")
    today_d = datetime.datetime.now()
    birth_t = birth_d.replace(year=today_d.year)
    if today_d > birth_t:
        age = today_d.year - birth_d.year
    else:
        age = today_d.year - birth_d.year - 1

    print('出生日期:%s' % birth_d)
    print('今年生日:%s' % birth_t)
    print('今天日期:%s' % today_d)
    print('如果今天日期大于今年生日,今年-出生年=年龄')
    print('如果今天日期不大于今年生日,今年-出生年-1=年龄')
    print('年龄:%s' % age)
    return age


if __name__ == '__main__':
    print(calculate_age('20171216'))
复制代码

 

放入sqlalchemy模型定义中,id_Num是身份证号,其中6-14位是出生日期。

复制代码
    @property
    def age(self):
        if len(self.id_Num) > 14:
            birth_s = self.id_Num[6:14]
            birth_d = datetime.datetime.strptime(birth_s, "%Y%m%d")
            today_d = datetime.datetime.now()
            birth_t = birth_d.replace(year=today_d.year)
            if today_d > birth_t:
                age = today_d.year - birth_d.year
            else:
                age = today_d.year - birth_d.year - 1
        else:
            age = 0
        return age
复制代码

引申一下,有身份证以后,性别也可以计算出来

复制代码
@property
    def gender(self):
        if len(self.IdNum) > 17:
            tag = self.IdNum[16:17]
            if (int(tag) % 2) == 0:
                result = ''
            else:
                result = ''
        else:
            result = '未知'
        return result
复制代码

加一个excel算性别

=IF(MOD(MID(D4,17,1),2),"男","女")

 

作者:上官飞鸿

出处:https://www.cnblogs.com/jackadam/p/12041838.html

版权:本作品采用「知识共享-署名-非商业性-禁止演绎(CC-BY-NC-ND)」许可协议进行许可。

posted @   上官飞鸿  阅读(6644)  评论(2编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2017-12-15 Django(一)创建和启动项目
more_horiz
keyboard_arrow_up light_mode palette
选择主题
点击右上角即可分享
微信分享提示