我們都知道,一個人的身份證號碼中包含了一個人非常多的隱私信息,如戶籍地、出生日期、年齡、性別等。如果我們想要知道某個人的部分信息,只需要將相關(guān)部分的代碼提取出來進行處理就可以得到結(jié)果了。
從身份證號碼中提取戶籍地信息
首先回答題主的問題,如何快速從身份證號碼中提取戶籍地信息?要做到這一點,我們必須要有一個“全國身份證歸屬地”數(shù)據(jù)庫表,相關(guān)數(shù)據(jù)內(nèi)容已經(jīng)放在Excel表格里了。如下圖所示:
我們該如何利用身份證號碼從右側(cè)表格中提取戶籍地信息呢?我們都知道,身份證號碼的前6位代表的是出生地信息。因此,
1.提取身份證號碼前6位。利用left函數(shù)來做:
=left(B2,6)
2.利用提取出來的代碼到數(shù)據(jù)庫中查詢戶籍地信息:
=vlookup(left(B2,6),I:J,2,)
3.我們發(fā)現(xiàn)并沒有查詢到正確的結(jié)果,這是怎么回事呢?原來提取出來的代碼只有6位,會被默認為數(shù)字,用數(shù)字到文本中進行查詢顯然是無法做到的,因此我們可以在提取到的代碼后面鏈接一個空文本將其強制轉(zhuǎn)化為文本。
=left(b2,6)&""
以同樣的方法處理一下:I:J列的數(shù)據(jù)庫。
=I:J&""
因此最終公式為:
{=VLOOKUP(LEFT(B2,6)&"",I:J&"",2,)}
最終效果圖如下:
從身份證號碼中提取出生日期
應(yīng)該說,這個需求要比題主的需求更加普遍,應(yīng)用得更加廣泛,當(dāng)然關(guān)于這一點做起來也不難。前面還用到了數(shù)組公式,搞定這個需求則完全不需要。不局限于函數(shù)的方法,用分列的方法更加簡單。
1.分列法
方法,選中B2:B86,單擊數(shù)據(jù)選項卡,分列,在打開的分列向?qū)е械谝徊焦催x固定寬度,第二步驟設(shè)置分隔線在第6位和第14位后面,第三步驟設(shè)置第1、3部分為“不導(dǎo)入此列”,中間列設(shè)置為YMD的日期格式,目標(biāo)區(qū)域設(shè)置為C2單元格,單擊完成即可。如下圖的演示:
2.函數(shù)法
思路:
1.利用Mid函數(shù)提取身份證號碼的第7位到14位(出生日期)
=mid(B2,7,8)
2.利用text函數(shù)將提取到的出生日期轉(zhuǎn)為看起來像日期:
=text(--mid(B2,7,8),"0-00-00")
3.由于text的結(jié)果為文本,我們需要再其前面加兩個負號,將其強制轉(zhuǎn)化為數(shù)字(日期):
=--text(--mid(B2,7,8),"0-00-00")
設(shè)置單元格的格式為短日期即可。
從身份證號碼知曉一個人的性別
身份證號碼的第17位為一個人的性別信息,奇數(shù)為男,偶數(shù)為女。
1.提取身份證號碼第17位數(shù)字。
=mid(b2,17,1)
2.判斷提取的數(shù)字的奇偶
=mod(mid(b2,17,1),2)
結(jié)果為1則是奇數(shù),返回結(jié)果男,否則返回結(jié)果女。
3.外層嵌套if函數(shù)
=if(mod(mid(b2,17,1),2),"男","女")
我們即可得到正確的結(jié)果。
如下圖所示:
我的回答就到這里,更多精彩內(nèi)容,敬請關(guān)注頭條號:傲看今朝。