楼主: 绿水菊
4866 3

[SAS EM] sas宏中使用字符函数看不同变量结果存在不同数据集 find?index?如何实现 [推广有奖]

  • 6关注
  • 1粉丝

讲师

59%

还不是VIP/贵宾

-

威望
0
论坛币
3 个
通用积分
13.1656
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
6800 点
帖子
213
精华
0
在线时间
514 小时
注册时间
2015-10-22
最后登录
2025-3-5

楼主
绿水菊 发表于 2017-11-13 21:40:43 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

请教大家一个sas程序。我的变量名字叫tw开头的,宏的最后一步想把数据存在x的数据集里面,类似的  变量名叫mb开头的,想存在y的数据集里面,如下是我想实现我这个目的的程序,结果不对,想请教下这个如何实现?(我如果不这么干会,如下面我引用的情况看出生成很多数据集,所以不会写高级的程序,就会导致工作量有点大mm的取值会排到一百多)

%if index(&var.,strip('tw'))>0 %then %do;

data x&mm.;
set aa&mm.;
run;
%end;

%if index(&var.,strip('mb'))>0 %then %do;

data y&mm.;
set aa&mm.;
run;
%end;
%mend lianxua;
%lianxua(dataz=heduo,var=tw2,y=5,smt=1,mm=1);
。。。。。
%lianxua(dataz=heduo,var=tw30,y=5,smt=1,mm=31);

%lianxua(dataz=heduo,var=mb2,y=5,smt=2,mm=32);
。。。
%lianxua(dataz=heduo,var=mb30,y=5,smt=2,mm=62);

非常感谢大家。

二维码

扫码加我 拉你入群

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

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

关键词:Index 如何实现 find SAS宏 IND sas宏 宏中使用字符函数

沙发
lovexialulu 发表于 2017-11-14 16:21:17
试试   %if %sysfunc(index(%str(&var.),tw)) %then %do;

藤椅
绿水菊 发表于 2017-11-17 20:57:07
谢谢这位老师,这两天有点其他事情耽搁了,所有我还没试。明天尝试哈,非常感谢。

板凳
苹果叶 在职认证  发表于 2017-11-17 21:34:50
lovexialulu 发表于 2017-11-14 16:21
试试   %if %sysfunc(index(%str(&var.),tw)) %then %do;
实际上在macro 里面这样用就好了
  1. %index(&var. tw)
复制代码


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

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