百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Excel VBA一键提取身份证信息,代码详解,手把手教你学编程

yuyutoo 2025-03-11 22:50 1 浏览 0 评论

在视频教程中我为大家展示了怎么使用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函数的功能,一步一步用代码实现,获取我们想要的数据,然后最后展示在单元格中。本文章需要配合视频教程和代码进行学习,效果更佳。视频课程可以点击我的头像,查看我的主页的视频课程,需要代码的同学可以私信我。希望本文对你有所帮助!

相关推荐

Windows中CMD最全命令行

CMD命令:开始->运行(或者Windows+R)->键入cmd或command(在命令行里可以看到系统版本、文件系统版本)CMD命令锦集1.gpedit.msc-----组策略2.s...

Linux常用文件操作命令

ls命令在Linux维护工作中,经常使用ls这个命令,这是最基本的命令,来写几条常用的ls命令。先来查看一下使用的ls版本#ls--versionls(GNUcoreutils)8.4...

Linux高阶知识:Linux 中的隐藏文件

在Linux系统的世界里,隐藏文件扮演着极为关键且神秘的角色。它们如同隐匿在黑暗中的守护者,默默支撑着系统的稳定运行,同时又蕴含着丰富的配置信息与个性化设置。对于普通用户而言,这些隐藏文件往往被忽...

linux基础命令之chattr命令

chattr命令是linux系统下用于修改文件的扩展属性的命令,相比chmod命令,chattr命令更加偏向于内核底层,这是因为chmod是修改文件的属性(包括读写,执行,所有者),而chattr命令...

命令干货:4个 Linux文件权限设置相关命令讲解

linuxchmod命令...

linux chmod 设置目录/子目录权限

linux中chmod修改目录权限已经在前面介绍过,详细见linuxchmod命令设置目录/文件权限详解那么如果要给目录下面的所有子目录都赋予相同的权限,需要用到参数...

linux下定位文件的常用命令

"find(1)是一种非常有用的shell脚本命令,但它往往被人们理解得不够透彻。这部分原因在于其复杂的语法(可以说是所有标准Unix命令中最复杂的,除了像awk这样的编程语言);另一部分原因在于手册...

Linux运维工程师必知必会的10个命令行组合

head1.日志分析:统计HTTP状态码分布...

Windows 与 Linux 文件权限的对比与转换

在Windows和Linux系统中,文件权限管理是非常重要的,但两者的文件权限机制存在一些显著的区别。以下是一篇技术性质的文章,探讨Windows和Linux系统中文件权限的对比与转换:Windows...

14天shell脚本入门学习-第十一天#用户和权限

用户与权限管理是系统管理中的重要任务,涉及创建、删除用户,管理用户组,以及设置文件和目录的权限。通过Shell脚本,可以自动化执行这些任务,提高管理效率。以下是用户与权限管理的详细说明和示例。...

分享几个Linux 提升运维效率的几个点

head1.快速切换目录...

这10个Linux命令太危险,千万慎用!数据毁灭的瞬间只需一个回车

你好,这里是网络技术联盟站,我是瑞哥。...

14天shell脚本入门学习-第六天#文件操作1

文件操作是Shell脚本中常见的任务之一,包括创建、读取、写入、删除文件,以及检查文件属性等。以下是Shell脚本中文件操作的详细说明和示例。...

2023年下半年计算机软考网络工程师试题解析

1、当计算机突然断电时,()中存储的信息会丢失。A.光盘B.ROMC.RAMD.硬盘【答案】C...

高级CLI:作为一名开发者你必须知道的命令

全文共2787字,预计学习时长8分钟来源:Pexels...

取消回复欢迎 发表评论: