Excel VBA之日期篇 4.5利用身份证获得员工基础信息 甚至籍贯
场景分析
今天的这些方法,主要集中在员工个人信息方面的一些处理,比方说性别,年龄,出生年月日等,同时顺带分享一个我收藏了好久的大招,籍贯的处理,这个需求是非常的偏门少见的,所以我当初也是百度了很久,翻遍了N多资料才找到的,今天分享给大家。今天主要涉及的一些文本方面的处理,大家可以趁机复习下文本方面的处理方法,同时也可以了解到简单的函数在工作中扮演的重要作用。
场景模拟
假设我们手上的这份表是这样子的,我们有了公司现在的部分员工的数据,这些数据都是从员工的简历上面获取的,这两个数据是肯定不会不错的,现在HR需要做一份全公司所有的员工的信息表,比方说获得对方的年龄,性别,生日,籍贯,那么我们需要如何用VBA来一步步实现呢?
我们来看看代码
Sub test()
Dim i&, sth As Worksheet, arr
arr = Range(Cells(2, 2), Cells(5404, 2))
arr = WorksheetFunction.Transpose(arr)
For i = 2 To 11
BOG = Right(Cells(i, "e"), 1) Mod 2
Bir = Mid(Cells(i, "e"), 7, 8)
SixNum = Int(Left(Cells(i, "e"), 6))
If BOG = 0 Then
Cells(i, "f") = "女"
Else
Cells(i, "f") = "男"
End If
Cells(i, "g") = WorksheetFunction.text(Bir, "0-00-00")
Cells(i, "h") = DateDiff("yyyy", Cells(i, "g"), Now)
r = Application.WorksheetFunction.Match(SixNum, arr, 0)
Cells(i, "i") = Cells(r + 1, 3)
Next i
End Sub
来看看看效果
是不是很完美呢
代码解析
今天的代码看起来比较的长,但是其实也没有多少太复杂的东西,都非常的简单,都是我们之前学习或者分享过的知识点,我们大致来说下
arr = Range(Cells(2, 2), Cells(5404, 2))
arr = WorksheetFunction.Transpose(arr)
这段代码的意思是获得一个数组,数组的方法虽然没有详细的说明,但是我们已经在之前分享过很多次数组的构造方法了,相信大家已经会了。
然后我们开始进行遍历
BOG = Right(Cells(i, "e"), 1) Mod 2
这里有一个方法需要大家学习下,我们通过身份证判断性别的时候,通常都是判断证件最后一位数是奇数还是偶数的,这个奇偶数的判断,就可以通过mod来实现,mod在其他的语言中也存在,是整除的意思,比方说python语句中也有这样的方法,能够被2整除,那就是偶数,代表是女性,不能被2整除那就是男性。这里我们先得到身份证最后最后一数除以2的结果,保存下来
Bir = Mid(Cells(i, "e"), 7, 8)
然后获得生日的8位数,这个用mid函数就可以了。
SixNum = Int(Left(Cells(i, "e"), 6))
赞 (0)