请选择 进入手机版 | 继续访问电脑版

 找回密码
 立即注册
搜索
热搜: Excel discuz
查看: 170|回复: 1

Excel中验证18位身份证号正确性

[复制链接]

160

主题

2万

元宝

23万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
236275
发表于 2020-3-26 20:45:26 | 显示全部楼层 |阅读模式
假设身份证号码(18位,文本格式)在D2单元格,则有效性检验公式为:

  1. =IF(LEFT(H5,17)&MID("10X98765432",MOD(SUM(MID(H5,1,1)*2^17,MID(H5,2,1)*2^16,MID(H5,3,1)*2^15,MID(H5,4,1)*2^14,MID(H5,5,1)*2^13,MID(H5,6,1)*2^12,MID(H5,7,1)*2^11,MID(H5,8,1)*2^10,MID(H5,9,1)*2^9,MID(H5,10,1)*2^8,MID(H5,11,1)*2^7,MID(H5,12,1)*2^6,MID(H5,13,1)*2^5,MID(H5,14,1)*2^4,MID(H5,15,1)*2^3,MID(H5,16,1)*2^2,MID(H5,17,1)*2^1),11)+1,1)=H5,"真实的","错")
复制代码
在实际操作中,需要把公式里所有的D2替换为你表格中的单元格坐标。



回复

使用道具 举报

160

主题

2万

元宝

23万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
236275
 楼主| 发表于 2020-3-28 20:16:18 | 显示全部楼层
使用这个公式更简便,志需要把B2替换成目标单元格就可以了。
  1. =RIGHT(B2)=MID("10X98765432",MOD(SUMPRODUCT(MID(B2,ROW($1:$17),1)*{7;9;10;5;8;4;2;1;6;3;7;9;10;5;8;4;2}),11)+1,1)
复制代码



回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|五花八门论坛

GMT+8, 2020-7-11 18:04 , Processed in 0.111219 second(s), 20 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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