sas正则式prxmatch
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
正则式:prxparse.Prxmatch
optionscompress=yes;
data dd;
input string$40.;
datalines;
我始终都抢不到2017年1月25号的票啊
今天是2017年1月23号
现在时间是9点17分
其实我很想我的妈咪
;
run;
data ss;
set dd;
if _n_=1then 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_=1then 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个数字。
这里注意的是,position返回的是他第一次遇到的关键字的位置,所以对于观测2的情况我们应该如何解决,这个问题下篇文章回答你。