Hello,大家好,今天跟大家介紹下身份證號(hào)碼是如何構(gòu)成的以及我們能從身份證號(hào)碼中提取到那些信息,廢話不多說(shuō),我們先來(lái)看下我們能從身份證號(hào)碼中得到那些信息吧
從上圖中可以看到,我們能從身份證號(hào)碼中提取6種信息,所有的數(shù)據(jù)提取都是建立在對(duì)數(shù)據(jù)源的理解之上,我們先來(lái)看下身份證號(hào)碼是如何組成的
(資料圖)
如上圖
第一位與第二位是省代碼,第三位與第四位是市代碼,第五位與第六位是區(qū)代碼
身份證的前6就構(gòu)成了我們的籍貫
第七位到第十四位是我們的出生日期
第十五位帶第十七位是順序碼,就是在同一區(qū)域中對(duì)同年同月同日生的人進(jìn)行按照順序標(biāo)號(hào),將順序碼的最后一位,也就是第十七位,奇數(shù)分給男性,將偶數(shù)分給女性
第十八位校驗(yàn)碼,根據(jù)前面的十七位數(shù)字,根據(jù)公式計(jì)算出來(lái)的,這個(gè)計(jì)算比較復(fù),跟我們的數(shù)據(jù)提取無(wú)直接關(guān)系,就不多做介紹了
了解了身份證號(hào)碼的組成,下面我們就來(lái)學(xué)習(xí)下如何提取身份證號(hào)碼中的數(shù)據(jù)
1.提取籍貫
公式:=VLOOKUP(LEFT(A3,6),Sheet2!A:B,2,0)
在這里我們首先使用LEFT(A3,6)函數(shù)來(lái)提取身份證號(hào)碼前6位,因?yàn)樵趕heet2中有籍貫對(duì)照表,所有我們可以使用vlookup函數(shù)進(jìn)行匹配查找
2.提取出生日期
公式:=–TEXT(MID(A3,7,8),”0-00-00″)
在這里我們先使用MID(A3,7,8)函數(shù)來(lái)提取身份證號(hào)碼中的出生日期,然后使用text函數(shù)將提取出來(lái)的出生日期設(shè)置為時(shí)間格式的顯示方式,因?yàn)槭褂胻ext函數(shù)設(shè)置過格式的數(shù)據(jù)它都是文本格式,所以我們?cè)诤瘮?shù)前面增加兩個(gè)減號(hào),將文本格式轉(zhuǎn)換為日期格式
3.提取年齡
公式:=DATEDIF(C3,TODAY(),”y”)
在這里我們使用datedif函數(shù)計(jì)算年齡,
第一參數(shù):C3就是我們上一步提取的出生年月第二參數(shù):today(),這個(gè)函數(shù)會(huì)返回當(dāng)前的日期第三參數(shù):“Y”,代表計(jì)算兩個(gè)日期的年份之差
4.判斷性別
公式:=IF(MOD(MID(A3,17,1),2)=1,”男”,”女”)
在這里我們首先使用mid函數(shù)來(lái)提取身份證號(hào)碼的第十七位,如果第十七位是奇數(shù)性別為男,如果為偶數(shù)性別為女
Mod函數(shù)是一個(gè)求余數(shù)的函數(shù),我們mod函數(shù)的第一參數(shù)設(shè)置為提取出來(lái)的身份證的第十七位,將mod函數(shù)的第二參數(shù)設(shè)置為2,當(dāng)有余數(shù)的時(shí)候mod的結(jié)果是1,當(dāng)沒有余數(shù)的時(shí)候mod的結(jié)果是0,
最后我們使用if函數(shù)判斷,在這里我們將條件設(shè)置為MOD(MID(A3,17,1)=1,這個(gè)的意思是判斷第十七數(shù)字是不是奇數(shù),如果是奇數(shù)函數(shù)的結(jié)果就是男,如果不是奇數(shù)函數(shù)的結(jié)果就是女
5.提取星座
公式:LOOKUP(–MID(A3,11,4),{100;120;219;321;421;521;622;723;823;923;1023;1122;1222},{“摩羯座”;”水瓶座”;”雙魚座”;”白羊座”;”金牛座”;”雙子座”;”巨蟹座”;”獅子座”;”處女座”;”天秤座”;”天蝎座”;”射手座”;”摩羯座”})
這個(gè)公式其實(shí)非常的簡(jiǎn)單,我們把它拆開來(lái)看就非常容易理解了
首先我們使用–MID(A3,11,4)函數(shù)來(lái)提取出生日期的月份以及天數(shù),因?yàn)閙id函數(shù)提取出來(lái)的結(jié)果都是文本格式,我們?cè)趍id函數(shù)前面加兩個(gè)減號(hào)將其轉(zhuǎn)換為數(shù)值格式
然后我們公式中看起來(lái)非常長(zhǎng)的兩列其實(shí)就是下圖的一個(gè)二維數(shù)組,只不過我們將其嵌套在公式中了
在這里lookup的第一參數(shù)是我們提取的數(shù)據(jù),第二參數(shù)是上表中的月份數(shù)值,第三參數(shù)是星座名稱,lookup查找數(shù)據(jù),我們需要先將數(shù)據(jù)升序排列,我們使用lookup如果找不到查找值,lookup函數(shù)會(huì)返回小于或等于查找值的最大值的這一特性來(lái)查找星座
6.提取屬相
公式:= =CHOOSE(MOD(MID(A3,7,4)-2008,12)+1,”鼠”,”?!?”虎”,”兔”,”龍”,”蛇”,”馬”,”羊”,”猴”,”雞”,”狗”,”豬”)
這個(gè)公式首先我們使用MID(A3,7,4),來(lái)提取出生的年份,然后我們將年份減去2008,有人會(huì)說(shuō)為什么,其實(shí)減去哪一年都可以,在這里2008對(duì)應(yīng)屬相是鼠,我們只要將減去的年份對(duì)應(yīng)屬相然后依次向后排列即可
然后我們使用mod函數(shù)求MID(A3,7,4)-2008這個(gè)結(jié)果對(duì)于12的余數(shù),最后加1是因?yàn)楫?dāng)沒有余數(shù)的時(shí)候結(jié)果是0,當(dāng)結(jié)果為0函數(shù)不能選取到鼠這個(gè)值,所以我們要加1,最后使用choose函數(shù)選取相應(yīng)的結(jié)果
Choose函數(shù)第一參數(shù)想要選取的值的位置,第二參數(shù):數(shù)據(jù)區(qū)域,函數(shù)中屬相的區(qū)域其實(shí)就是一列數(shù)據(jù),只不過我們將其嵌套在函數(shù)中
以上就是我們從身份證號(hào)碼中提取6中信息的方法,僅做了比較簡(jiǎn)單的介紹,不知道大家都能學(xué)會(huì)多少呢,如果覺得實(shí)在是學(xué)不會(huì)的話,其實(shí)是可以直接套用公式,更改下函數(shù)單元格位置即可,身份證號(hào)碼包含這么多信息,大家一定要好好保護(hù)自己身份證號(hào)碼
關(guān)鍵詞: