京公网安备 11010802034615号
经营许可证编号:京B2-20210330
sas正则式之prxparse. Prxmatch
今天分享的是我这几天用到的正则式的一个小总结,这部分的内容因为比较多,所以会分成几篇文章分享。
其实我们在做数据的过程中老是会听到别人说,r处理数据比sas好用,但是在我理解里,看你先接触那个软件,你都很熟悉r了,你还会再花两三年去写sas吗?所以学软件,只要学的精,其实都是共通的,r能做的文本清洗的,sas也可以。但是我不是说你就不要去学r,我自己也会学R,在工作中也需要结合使用。只是希望你们不要对sas有偏见,毕竟我深爱sas胜过男朋友。
话太多了哈,毕竟白羊座嘛。上代码:
options compress=yes;
data dd;
input string$40.;
datalines;
我始终都抢不到2017年1月25号的票啊
今天是2017年1月23号
现在时间是9点17分
其实我很想我的妈咪
;
run;
data ss;
set dd;
if _n_=1 then ret=prxparse("/\我/");
retain ret;
position=prxmatch(ret,string);
run;
结果图如下:
Prxparse这个函数不能单独使用,都是和其他正则函数一起结合使用的,这个结果就不用看ret了,运行是pdv层面的事,我就不多说,这里要关注的prxmatch函数返回的关键字的位置。
prxmatch(ret,string)
ret填入的是prxparse返回的一个逻辑数,即0和1,以上面的例子为例,假设prxparse在变量string中没有找到“我”这个词,那么返回的0,反之返回1.你问我为什么上面的结果ret中的值是1,那是因为ret记录的只是第一条观测的ret的值,这个变量你就直接不看就行了。但是你要记住prxmatch是怎么跑的。即ret在要那条观测判断为1时,prxmatch就执行,在string中“我”的位置并返回。这里中文占两个字符哈。
这是一个简单的例子,现在具体介绍下常用的一个关键字的表述。
例如:
1、 Prxparse(”/\d\d\d/”)寻找任意的三个数字,这里要注意的是关键字必须用{“//”}圈起来。
2、 Prxparse(”/\d+/”)寻找一个以上的数字,可以是1个也可以是100个
3、 Prxparse(”/\w\w\w* /”)寻找两个以及两个以上的字符然后以空格分隔,*号后面有个空格,你再多看几眼。譬如你要寻找屁屁 后者屁屁屁 你就可以这么写Prxparse(”/\屁\屁\屁* /”)
4、 Prxparse(”/\w\w? + /”)寻找一个或者两个字符以一个空格或者多个空格分隔。看清楚哈,?后面是有空格的哈。这个总结一下,就是字符多的用*号,空格和数字多个用+号。
5、 Prxparse(”/(\w\w) +(\d) +/”)寻找一个两个字符之间与一个数字相隔一个或者多个空格的字符。注意,在正则式中,空格也算的,所以写的时候要小心。那这里举个栗子,就是譬如 “我是屁屁 2 ”那么就会找到:“屁屁 2 ”。
现在列出经常用到的关键字返回的数据类型:
不准说你英文看不懂,我大学四级考了四年才过的人不也照样看了。看不看懂取决你愿不愿意看,难道从小学学到大学的英文都被狗吃了吗?数据分析师培训
看过关键字的表述,给出一些例子熟悉一些这些表述:
这是针对Prxparse函数的例子:
一下是针对prxmatch(返回string的位置)函数的例子:
现在来个现实生活中会碰到的问题。
寻找电话号码:
data ee;
input string$40.;
cards;
电话:(123)333-4444
两个电话:(800)234-2222 和 (908) 444-2344
没有电话
;
run;
data ww;
set ee;
if _n_=1 then ret=prxparse("/\(\d\d\d\) ?\d\d\d-\d{4}/");
retain ret;
position=prxmatch(ret,string);
run;
结果:
prxparse("/\(\d\d\d\) ?\d\d\d-\d{4}/");这条正则式的意思是:
匹配有括号里中3个数字,然后不知道有木有空格为间隔之后再接三个数字之后加一个横杠之后加4个数字。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数据分析、用户运营与业务增长的工作体系中,漏斗拆解是最基础也最高频的问题定位方法。很多业务场景下,我们只能看到最终的转 ...
2026-06-17在数据库开发、数据清洗与报表统计场景中,数值类型转换为日期是高频刚需操作。业务系统常以 Unix 时间戳、整型日期(如20240617 ...
2026-06-17 数据分析师八成以上的时间在和数据表格打交道,但许多人拿到Excel后习惯性地先算、先分析,结果回头发现漏了一列关键数据, ...
2026-06-17【核心关键词】数据库、电商、知识、产品、数据产品、监管业务、产品经理、业务系统、用户行为分析、用户分析、数据分析、电商 ...
2026-06-16在 Python 动态类型与面向对象的编程体系中,变量定义与类实例化是构建代码逻辑的两大核心基石。变量是数据存储、传递与运算的基 ...
2026-06-16 很多数据分析师每天与Excel打交道,但当被问到“表格结构数据和表结构数据有什么区别”“数据类型误判会引发哪些分析错误” ...
2026-06-16在 MySQL 查询性能优化体系中,索引是降低查询耗时、提升数据库吞吐的核心手段。其中联合索引与覆盖索引是实际开发中最高频的两 ...
2026-06-15在数据仓库建设与商业智能分析体系中,维度建模是应用最广泛的建模方法论,而事实表与维度表是维度建模的两大核心构件,共同构成 ...
2026-06-15 很多数据分析师能熟练计算指标,但当被问到“这家企业的核心业务目标是什么”“如何把模糊的战略目标拆解为可量化的指标”“ ...
2026-06-15在数据分析、业务监控、运营复盘等场景中,列值趋势计算是核心需求之一。无论是分析销售额的月度增长、用户活跃的变化趋势、库存 ...
2026-06-12在数字经济深度渗透的当下,消费者的购买行为已从过去的 “被动接受” 转变为 “主动决策”。流量红利消退、获客成本攀升、用户 ...
2026-06-12CDA三级认证是三个级别中的塔尖,全面考察数据战略、团队领导和复杂项目的综合能力。它所对应的《敏捷数据挖掘》教材,不再局限 ...
2026-06-12在游戏产业的商业逻辑中,付费玩家是支撑游戏生存与发展的核心支柱。行业普遍遵循 “二八定律”:20% 的付费玩家贡献了游戏 80% ...
2026-06-11【核心关键词】企业、定位、传统、产品、互联网、可视化、业务侧、数字化、结构化、数据分析、传统制造业、市场状态、发展空间 ...
2026-06-11 解读《CDA二级教材:量化策略分析(2025)》的全景结构与学习逻辑 ” CDA二级认证是企业招聘数据分析师时最常提及的证书门槛 ...
2026-06-11【核心关键词】药企、可视化、营销、分类、数据分析师、销售数据、业务人员、指导方向、分析报告、营销数据、营销医生 【专访摘 ...
2026-06-10在统计学分析、问卷调研、实验验证、业务复盘等场景中,卡方检验与 T 检验是应用最广泛的两类基础假设检验方法。前者专门处理分 ...
2026-06-10 很多数据分析师每天都在计算指标、制作报表,但当被问到“什么叫指标数据元”“指标数据标准包含哪些核心维度”“指标数据质 ...
2026-06-10在MySQL数据库日常查询、数据统计、后台接口开发、数据导出等场景中,开发者经常需要查询数据表除某几列之外的所有字段。例如查 ...
2026-06-09在Python网络请求、爬虫开发、接口测试、数据抓取等实操场景中,requests库是最常用的第三方请求工具,而content属性是requests ...
2026-06-09