楼主: anzhiliang
2287 7

关于Macro 里是否能用array 的问题 [推广有奖]

  • 0关注
  • 0粉丝

博士生

38%

还不是VIP/贵宾

-

威望
0
论坛币
1240 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
2027 点
帖子
136
精华
0
在线时间
410 小时
注册时间
2009-8-21
最后登录
2022-5-2

楼主
anzhiliang 发表于 2010-5-21 14:58:34 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
我有个问题如题,
%macro jsx();
%do i=1 %to 97;
data jsx&i.;
set sa.timescore3;
array jsx(97) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 17 18 19 20
21 22 23 24 25 26 27 28 29 30 31 32 33 40 41 42 43 46 47 49
50 53 54 55 57 58 60 61 62 63 64 65 66 71 72 73 74 75 77 79
81 83 84 85 87 88 89 90 91 93 96 98 99 101 109 110 113 114
115 117 120 121 123 124 128 131 133 134 138 140 143 144 147 149 166 281 282 285 ;
if hospital_id=jsx(i);
%end;
run;
%mend jsx;
%jsx();
我想根据array jsx(i)的值建立数据集但不知道macro 里能不能用数组。
谢谢。
二维码

扫码加我 拉你入群

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

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

关键词:array Macro Mac ARR acr Macro array

回帖推荐

pobel 发表于2楼  查看完整内容

能用 %macro jsx(); %do i=1 %to 97; data jsx&i.; set sa.timescore3; array jsx(97) (1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 40 41 42 43 46 47 49 50 53 54 55 57 58 60 61 62 63 64 65 66 71 72 73 74 75 77 79 81 83 84 85 87 88 89 90 91 93 96 98 99 101 109 110 113 114 115 117 120 121 123 124 128 131 133 134 138 140 143 144 147 149 166 281 282 ...

本帖被以下文库推荐

沙发
pobel 在职认证  发表于 2010-5-21 15:10:12
能用

%macro jsx();
%do i=1 %to 97;
data jsx&i.;
set sa.timescore3;
array jsx(97) (1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 17 18 19 20
21 22 23 24 25 26 27 28 29 30 31 32 33 40 41 42 43 46 47 49
50 53 54 55 57 58 60 61 62 63 64 65 66 71 72 73 74 75 77 79
81 83 84 85 87 88 89 90 91 93 96 98 99 101 109 110 113 114
115 117 120 121 123 124 128 131 133 134 138 140 143 144 147 149 166 281 282 285) ;
if hospital_id=jsx(&i);
run;
%end;
%mend jsx;
%jsx();
已有 1 人评分经验 论坛币 收起 理由
bakoll + 3 + 3 精彩帖子

总评分: 经验 + 3  论坛币 + 3   查看全部评分

藤椅
棍子2007 发表于 2010-5-21 15:11:21
好难啊,有什么更好的办法么啊

板凳
anzhiliang 发表于 2010-5-21 15:12:36
2# pobel [/]

万分感谢,这个问题困扰我好几天。

报纸
pobel 在职认证  发表于 2010-5-21 15:23:17
data _null_;
   call execute("data");
   do j=1 to 97;
       call execute("jsx"||strip(j));
   end;
   call execute("; set sa.timescore3; array jsx(97) (1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 17 18 19 20
        21 22 23 24 25 26 27 28 29 30 31 32 33 40 41 42 43 46 47 49
        50 53 54 55 57 58 60 61 62 63 64 65 66 71 72 73 74 75 77 79
        81 83 84 85 87 88 89 90 91 93 96 98 99 101 109 110 113 114
        115 117 120 121 123 124 128 131 133 134 138 140 143 144 147 149 166 281 282 285);");  
   do i=1 to 97 ;
   call execute("if hospital_id=jsx("||strip(i)||") then output jsx"||strip(i)||";");
   end;
   call execute("run;");
run;

地板
pobel 在职认证  发表于 2010-5-21 15:34:00
......
......
call execute("drop jsx:;");
call execute("run;");
run;

7
soporaeternus 发表于 2010-5-21 17:40:26
貌似if hospital_id=jsx(i);改成if hospital_id=jsx(&i);就可以了,但是这样效率很差啊......
5楼好强......
加个else-if就完美了
Let them be hard, but never unjust

8
crackman 发表于 2010-5-21 19:58:24
学习了

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

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