【社区答疑】帮公安干警提取车牌号信息
WPS函数专家
要想下班早,表格必须用的好!
大家好,我是张俊。
⭐场景
前段时间在社区看到@清华学弟任泽岩大佬(泽岩师兄)发布动态数组行业案例:帮公安干警提取车牌的帖子,让我学习到了很多知识,如函数用法、问题分析、逻辑思路和场景应用等,在此特别感谢@清华学弟任泽岩大佬(泽岩师兄)和@汪道长汪英伦老师。具体如下图所示:
但是一直感觉泽岩师兄需要借助辅助表(各省级车牌号简称)来查找,我也一直想跳过辅助表看是否可以完成。另也发现具体问题如下:
1)通过一长串函数计算处理的结果与数据源顺序不一致
2)通过FIND函数只能查找第一次匹配的位置,如果出现了同省两个车辆信息,则会出现错误
3)当出现不符合的标点符号也许会被计算出来
- 问题分析
1.1 车牌号格式
我们先来了解下常见的车牌号(比较特殊的暂时不考虑,只考虑最常见的车牌号)格式,各地省份简称+大写字母+5-6位大写字母和数字混合,具体如下:
还是老规矩,我们重新来分析问题,我们需要判断是否为车票号的要素并且需要根据ASCII码来判断,具体如下:
1)车牌号第1个字符为汉字(ASCII码大于122)
2)车牌号第2个字符为大写字母(ASCII码大于123在65到90之间)
3)车牌号第3-7/8位应为大写字母或0-9数字混合(ASCII码大于123在48到90之间,且不包含58至64)
1.2 ASCII码是啥?
ASCII(American Standard Code for Information Interchange)码是一种常用的字符编码标准,最初由美国国家标准学会(ANSI)于1963年发布,后来被国际标准化组织(ISO)接受为国际标准ISO 646。大家如果感兴趣的话,可以在网络上搜索和详细了解,在此就不一一赘述。
1.3 ASCII码与WPS表格函数
说了这么多ASCII码,那与WPS表格函数有啥关系了呢?当然有了,我们可以通过CHAR函数将数字转化为对应的字符(从左到右),也可以通过CODE函数将字符转化为数字(从右到左),具体如下图所示:
通过上图可以看出,对我们当前最常用的就是48至122之间,如果只考虑大写字母不考虑小写字母的话,就是48到90之间,且不考虑58至64。
因此如果我们使用常规的函数来处理的话,就需要通过CODE函数来判断字符是否满足。
- JS宏自定义函数
首先想到的方法就是通过正则表达式提取,而WPS表格默认自带的JS宏就支持自定义函数,代码具体如下:
function REG(rng,str1,str2){
//入参1:需要处理的单元格区域
//入参2:需要编写的正则表达式字符串
//入参3:如匹配多个数据,之间的连接符
return rng.Value2.match(eval(str1)).join(str2)
}
具体公式如下:
=reg(A2,"/\W[A-Z]\w{5,6}/g","、")
实现效果如下图所示:
- 内测REGEXP函数
同理通过WPS表格内测版本的REGEXP函数(正则表达式)配合TEXTJOIN函数也可以完成,具体公式如下:
=TEXTJOIN("、",,REGEXP(A2,"\W[A-Z]\w{5,6}"))
具体效果如下图所示:
📢 | 注意: REGEXP函数(正则表达式)目前还是内测函数,预计在2024年4月底或5月初正式上线,如果大家无法内测的话,建议大家耐心等待一下。 |
- 正式版已支持函数
能否能用现有可以使用的正式版支持呢?答案是肯定的,只不过公式写的稍微过长,具体公式如下:
=TEXTJOIN("、",,TOROW(IF((CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))))),1))>122)*IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+1,1))>64,0)*IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+1,1))<91,0)*IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+6,1))>47,0)*IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+6,1))<91,0),MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))))),IF(IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+7,1))>47,0)*IFERROR(CODE(MID(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),SEQUENCE(LEN(CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58))))))+7,1))<91,0),8,7)),""),3))
具体函数公式简单解析如下图所示:
具体效果如下图所示:
- 通过LET函数简化公式
发现上面的公式太长了,能否通过现有的LET函数简化下呢?那是必须的,通过LET函数简化后的公式来了,具体如下:
=LET(a,CONCAT(TEXTSPLIT(A2,CHAR(SEQUENCE(7,,58)))),b,SEQUENCE(LEN(a)),TEXTJOIN("、",,TOROW(IF((CODE(MID(a,b,1))>122)*IFERROR(CODE(MID(a,b+1,1))>64,0)*IFERROR(CODE(MID(a,b+1,1))<91,0)*IFERROR(CODE(MID(a,b+6,1))>47,0)*IFERROR(CODE(MID(a,b+6,1))<91,0),MID(a,b,IF(IFERROR(CODE(MID(a,b+7,1))>47,0)*IFERROR(CODE(MID(a,b+7,1))<91,0),8,7)),""),3)))
具体函数公式简单解析如下图所示:
具体效果如下图所示:
- 方法总结
本次分享了4种方法分别是JS宏自定义函数、内测REGEXP函数、现有支持函数和通过LET函数简化,都是可以不依赖辅助表,都可以严格规避无效字符,也避免了前面所提及的问题,这4种方法各有优劣,具体如下:
1)JS宏自定义函数,对WPS表格的支持的JS宏版本的函数都适用,只是不管是书写代码还是自定义函数的公式,都是相对比较简单的;但是对于初学者不太友好,只能“依葫芦画瓢”。
2)内测REGEXP函数对于即将发布的新版本来说,是相对更加简单通俗易懂;但是也需要掌握正则表达式的专业知识,才能写出更加符合自己习惯的函数公式,也需要等待支持REGEXP函数的版本发布后才能使用。
3)现有支持的函数公式,虽然现在最新版都已经可以使用;但是逻辑复杂,书写更加费劲,需要较强的思维逻辑和函数公式的调试能力。
4)通过LET函数简化后,虽然看起来更加简单了,但是理解难度大大增加。
以上4种方法建议大家根据自己的需求选择适合自己的方法,也欢迎大佬们有更好的方法可以具体说明。
都看到这里了,记得得❤️❤️❤️点赞(红心)❤️❤️❤️和⭐⭐⭐收藏(五角星)⭐⭐⭐并在评论区评论“我学会了!”,您的❤️❤️❤️点赞(红心)❤️❤️❤️、⭐⭐⭐收藏(五角星)⭐⭐⭐和评论是对我最大的支持!
🚩 | 练习文件:👉【社区答疑】帮公安干警提取车牌号信息👈 |
个人往期帖子合集:【帖子合集】个人往期帖子合集来了!
相关帖子链接:动态数组行业案例:帮公安干警提取车牌
WPS函数专家
创作者俱乐部成员
WPS函数专家
WPS函数专家
创作者俱乐部成员
WPS函数专家
创作者俱乐部成员
创作者俱乐部成员
WPS函数专家
创作者俱乐部成员
WPS函数专家