楼主: 乐天天12300
635 3

[问答] 为何select-when语句严格要求字句以一个;结尾,多一个就会报错 [推广有奖]

  • 0关注
  • 3粉丝

已卖:352份资源

讲师

96%

还不是VIP/贵宾

-

威望
0
论坛币
4875 个
通用积分
360.1222
学术水平
60 点
热心指数
70 点
信用等级
42 点
经验
9962 点
帖子
243
精华
0
在线时间
1004 小时
注册时间
2016-11-28
最后登录
2025-5-3

楼主
乐天天12300 发表于 2023-1-30 15:26:53 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

data test;
set sashelp.class;


/*以下语句如果有多个分号结尾,则会报错*/
select(sex);;
  when("男")  sex='1';
  when("女")  sex='2';
  otherwise sex=' ';
end;
run;


这种行为和SAS其他语句相比似乎显得特别。
二维码

扫码加我 拉你入群

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

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

关键词:Select Elect when LEC ele

沙发
橙红的果士 学生认证  发表于 2023-1-31 13:26:40
不清楚原因,感觉像是data步和sql步的杂合,可以单纯使用data步的if或者sql步的case when,这样分号的要求就不那么复杂了
  1. proc sql;
复制代码

藤椅
whymath 发表于 2023-2-1 13:24:57
据一位热心网友:
一个单独的 ; 就是一个空语句,放在其它地方或许是合法的,但放在 select 语句后则不合适,因为 select 语句后仅支持 when、otherwise、end 语句。

若你仔细观察你的程序在日志中的报错,应该能有所收获。

板凳
乐天天12300 发表于 2023-2-1 18:09:36
whymath 发表于 2023-2-1 13:24
据一位热心网友:
一个单独的 ; 就是一个空语句,放在其它地方或许是合法的,但放在 select 语句后则不合 ...
非常感谢

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

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