设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12下一页
返回列表 发新帖
查看: 4749|回复: 11
打印 上一主题 下一主题

[模块/函数] 一个用于验证18位身份证号码有效性的通用函数

[复制链接]
跳转到指定楼层
1#
发表于 2010-8-24 01:36:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 红尘如烟 于 2010-8-24 02:09 编辑
  1. '===================================================================
  2. '函数名称: IsIDNumber
  3. '功能描述: 根据GB11643-1999编码规则验证18位身份证号码是否有效
  4. '输入参数: 参数1:IDNumber 必需的,18位身份证号码
  5. '返回参数: 有效返回True,无效返回False
  6. '兼 容 性:
  7. '使用示例: IsIDNumber("370284197901130819") '返回True
  8. '相关调用:
  9. '作 者: 红尘如烟
  10. '创建日期: 20010-4-25
  11. '===================================================================
  12. Function IsIDNumber(ByVal IDNumber As String) As Boolean
  13. Const W As String = "79058421637905842" '加权因子
  14. Const C As String = "10X98765432" '校验码
  15. Dim S As Integer, i As Integer, T As Integer

  16. IDNumber = UCase(Trim(IDNumber))
  17. If Len(IDNumber) <> 18 Then Exit Function
  18. If Not IsNumeric(Mid(IDNumber, 1, 17)) Then Exit Function
  19. If Not IDNumber Like "*[0-9X]" Then Exit Function


  20. For i = 1 To 17
  21.     T = Mid(W, i, 1)
  22.     If T = 0 Then T = 10
  23.     S = S + Mid(IDNumber, i, 1) * T
  24. Next
  25. T = S Mod 11
  26. If Right(IDNumber, 1) = Mid(C, T + 1, 1) Then IsIDNumber = True
  27. End Function
复制代码

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 分享淘帖 订阅订阅
2#
发表于 2010-8-24 08:11:01 | 只看该作者
这个不错哦 ,好东西呀!我要下了!多谢!多谢!!
3#
发表于 2010-8-24 08:17:34 | 只看该作者
下了
4#
发表于 2010-8-24 09:19:20 | 只看该作者
收下

点击这里给我发消息

5#
发表于 2010-8-24 11:26:20 | 只看该作者
谢谢分享!
6#
发表于 2010-8-24 20:50:23 | 只看该作者
三克油,饿骆驼
7#
发表于 2010-8-24 15:17:29 | 只看该作者
8#
发表于 2010-8-24 15:23:10 | 只看该作者
谢谢分享
9#
发表于 2010-8-24 15:28:02 | 只看该作者
这个不错哦 ,好东西呀!我要下了!多谢!多谢!!

点击这里给我发消息

10#
发表于 2010-8-26 11:16:07 | 只看该作者
好东西,收藏了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2025-1-11 16:44 , Processed in 0.097129 second(s), 33 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表