网站首页 > 精选文章 正文
在视频教程中我为大家展示了怎么使用VBA编程,一键就可以通过身份证号码获取到个人相关信息。视频教程限于篇幅没法给大家详细讲解代码,所以这篇文章将为大家带来视频中展示的代码的详细讲解。
基础知识
在excel的文档中如果插入了宏的代码,那么我们需要把文件保存为.xlsm格式,并且打开excel工作簿的时候要启用宏。
按住alt+f11能调出VBA的代码编辑器。
【开发工具】选下卡的插入可以插入按钮等表单控件。
在VBA代码编辑器中定义好一个宏后,可以插入一个按钮,然后右键点击按钮指定宏,这样能给按钮指派宏,当点击按钮就会触发宏当中的VBA代码。
实现一键提取信息的步骤
我们要实现通过选中批量的身份证信息,然后使用VBA代码一键获取性别、出生年月日以及年龄等信息的步骤如下:
1.获取选中的单元格内容
2.判断是否选中了多个单元格
3.判断是否选中的是同一列的单元格
4.循环遍历选中的身份证信息,截取对应位数的数字,判断性别、生日
5.根据当前时间和生日,用函数算出年龄
6.把算出的信息放在对应单元格上面
代码讲解
全局代码如下:
这一段是定义一个名字叫【从身份证号码获取信息】的宏,End Sub是结尾,中间是功能代码:
Sub 从身份证号码获取信息()
......
End Sub
这一段是在定义后面可能会用到的变量,变量相当于存放数据的盒子:
Dim rng As Range, i As Integer, Mystr As String, arr, arr2()
这一段是在判断当前你在工作表中是否选中了单元格,如果没选中就会报出错误信息并退出执行代码,后面的代码不会再执行,出现Exit Sub就会终止执行后面的代码:
If TypeName(Selection) <> "Range" Then MsgBox "请选择存放身份证号码的区域": Exit Sub
返回选中单元格和当前活动sheet中有内容的单元格间重复的单元格,也就是去除你选中了,但是没有值的空单元格,Intersect是一个函数,这个函数的作用是返回两个参数中的单元格部分的重合部分:
Set rng = Intersect(Selection, ActiveSheet.UsedRange)
这两段代码也是在判断和限制你选中的单元格内容,就不做详细讲解了,请参考代码注释:
If rng.Columns.Count > 1 Then MsgBox "只能选择单列", vbOKOnly + vbInformation, "出错提示": Exit Sub
If rng(1) = "" Then MsgBox "请选择身份证号码存放区域", vbOKOnly + vbInformation, "出错提示": Exit Sub
这里是在开始进行循环,然后处理相似的操作,为什么要循环,这是因为,我们对几个身份证号码进行提取的规则是一样的,变化的只是号码不同,所以这就可以用循环来实现,否则一个一个写代码会非常多也很麻烦:
For i = 1 To UBound(arr)
......
Next i
截取身份证号从第15位开始,总共取3位,然后除以2取余数,Mod是取余数的操作。如果余数是1就是奇数,那么就是男,反之位0那么就是偶数,性别就是女。
arr2(i, 1) = IIf((Mid(arr(i, 1), 15, 3) Mod 2), "男", "女")
身份证号如果是15位,并且第7位如果是0,那么证明是00后,那么生日的年份就要加上20,然后取7,8位和20拼接起来,组成年份,中加用“-”连接,然后9,10位位月份;11,12位为日,这样就组成了出生生日:
If Len(arr(i, 1)) = 15 And Mid(arr(i, 1), 7, 1) = 0 Then Mystr = "20" & Mid(arr(i, 1), 7, 2) & "-" & Mid(arr(i, 1), 9, 2) & "-" & Mid(arr(i, 1), 11, 2)
和上面类似,15位身份证,当第7位大于0就应该在前面加上19,而不是加20,其余部分和上面一样:
If Len(arr(i, 1)) = 15 And Mid(arr(i, 1), 7, 1) > 0 Then Mystr = "19" & Mid(arr(i, 1), 7, 2) & "-" & Mid(arr(i, 1), 9, 2) & "-" & Mid(arr(i, 1), 11, 2)
18位的身份证,这个内容较简单,相信大家根据上面的讲解能够举一反三:
If Len(arr(i, 1)) = 18 Then Mystr = Mid(arr(i, 1), 7, 4) & "-" & Mid(arr(i, 1), 11, 2) & "-" & Mid(arr(i, 1), 13, 2)
Evaluate函数能把字符串内容,当作代码去执行,这段代码主要是为了执行DATEDIF函数用当前时间减去生日,这样就能计算出年龄:
arr2(i, 3) = Evaluate("DATEDIF(" & DateSerial(Split(Mystr, "-")(0), Split(Mystr, "-")(1), Split(Mystr, "-")(2)) * 1 & ", NOW()," & """Y""" & ")")
这里就是在做赋值的工作,前面所有计算结果都是放在arr2这个变量中,我们可以理解为放在arr2盒子中,这段代码执行后就会把计算结果放在相应的单元格中了。
rng.Offset(0, 1).Resize(UBound(arr), 3) = arr2
结语
学VBA编程就需要我们先理清楚实现业务场景的步骤,然后查阅相关VBA函数的功能,一步一步用代码实现,获取我们想要的数据,然后最后展示在单元格中。本文章需要配合视频教程和代码进行学习,效果更佳。视频课程可以点击我的头像,查看我的主页的视频课程,需要代码的同学可以私信我。希望本文对你有所帮助!
猜你喜欢
- 2025-06-04 Excel制作自定义日历控件,功能实用,实在有用了
- 2025-06-04 VBA基本语法之逻辑运算符、通配符,有什么作用,它们该怎么使用
- 2025-06-04 用VB.NET做关于窗口(用vbs写一个窗口)
- 2025-06-04 Stimulsoft Reports.Net开发者常见问题及解决方案--报表输出
- 2025-06-04 ExcelVBA函数:将单元格区域转换为【表】,并格式化为特定主题
- 2025-06-04 超实用!手把手教你制作Excel日程提醒
- 2025-06-04 VB编程(八)常量和变量(vb中的常量有哪几种类型)
- 2025-06-04 VBA日期函数 -> DateDiff计算时间差
- 2025-06-04 基于对象的Excel VBA的分层对象集合及外部对象库
- 2025-06-04 初中生也能学的编程,不走弯路,先用后学
- 最近发表
- 标签列表
-
- 向日葵无法连接服务器 (32)
- git.exe (33)
- vscode更新 (34)
- dev c (33)
- git ignore命令 (32)
- gitlab提交代码步骤 (37)
- java update (36)
- vue debug (34)
- vue blur (32)
- vscode导入vue项目 (33)
- vue chart (32)
- vue cms (32)
- 大雅数据库 (34)
- 技术迭代 (37)
- 同一局域网 (33)
- github拒绝连接 (33)
- vscode php插件 (32)
- vue注释快捷键 (32)
- linux ssr (33)
- 微端服务器 (35)
- 导航猫 (32)
- 获取当前时间年月日 (33)
- stp软件 (33)
- http下载文件 (33)
- linux bt下载 (33)