楼主: lorpercon
1809 2

SAS base find() 问题 [推广有奖]

  • 1关注
  • 0粉丝

硕士生

22%

还不是VIP/贵宾

-

威望
0
论坛币
543 个
通用积分
3.7591
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
210 点
帖子
204
精华
0
在线时间
77 小时
注册时间
2012-1-16
最后登录
2017-5-12

楼主
lorpercon 发表于 2015-6-4 01:48:06 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
jijin 看了晕头转向,几个关于find()的原题和变体,原题:

42.The following SAS program is submitted:

  data WORK.ONE;

    Text='Australia, US, Denmark';

    Pos=find(Text,'US','i',5);

  run;

答案是12,这个5说明从Australia里的a开始往右数,不分大小写找US, 应该是7才对嘛? 选项里根本没有7,不太明白()里面的数字怎么用,解释说表示从第几个开始数。。。


多谢指教



二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:SAS base Base find Fin IND following

沙发
sas那个石家庄人 发表于 2015-6-4 07:55:20

dataWORK.ONE;
    Text='Australia, US, Denmark';
    Pos=find(Text,'US','i',5);

是这样的find返回的数据是 “us”在整个string里面的位置
而5是让find从第5个字符开始找,这样就可以忽略第一个出现的us了


补充下 你把5改成 3 或 4 得到的结果是一样的。 但是你把5改成2,那么find返回的值就是2了。因为2会让find从第一个us就开始找。

藤椅
lorpercon 发表于 2015-6-4 09:41:31 来自手机
太谢谢了,这么一说大彻大悟

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-27 10:13