楼主: reolin
3232 6

哪位知道其运行结果中flag=3不显示出来的原因 [推广有奖]

  • 0关注
  • 0粉丝

已卖:217份资源

硕士生

69%

还不是VIP/贵宾

-

威望
0
论坛币
2268 个
通用积分
0.1200
学术水平
0 点
热心指数
1 点
信用等级
0 点
经验
2086 点
帖子
125
精华
0
在线时间
168 小时
注册时间
2008-11-28
最后登录
2022-7-29

楼主
reolin 发表于 2010-9-9 22:54:43 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
PROC IMPORT OUT= WORK.a1
            DATAFILE= "d:\My Documents\ssfz\hb1.xls"
            DBMS=EXCEL2000 REPLACE;
     SHEET="sheet1$";
     GETNAMES=YES;
RUN;
PROC IMPORT OUT= WORK.a2
            DATAFILE= "d:\My Documents\ssfz\hb2.xls"
            DBMS=EXCEL2000 REPLACE;
     SHEET="sheet1$";
     GETNAMES=YES;
RUN;
data a;
set a1(keep=gdp cpi);
if cpi>=110 then flag1=1;
else if cpi>105 then  flag1=2;
if flag1;
proc print data=a;
run;
data b;
set a2(keep=gdp cpi);
if gdp>28000 then flag2=3;
if flag2;
proc print data=b;run;

proc sort data=a;by gdp;run;
proc sort data=b;by gdp;run;
data c;
merge a(in=a) b(in=b);
by gdp;
if a or b;
if flag1=1 or 2 then flag=flag1;
else flag=3;
drop flag1 flag2;

run;
proc print data=c ;run;
二维码

扫码加我 拉你入群

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

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

关键词:Flag lag Fla 不显示 documents 运行 结果 Flag

回帖推荐

soporaeternus 发表于6楼  查看完整内容

一种是直接新建一个变量if flag1=1 then flag2="过高值等等";这样来赋值 还有种就是用format来做 上面给了个例子 希望对你有帮助

本帖被以下文库推荐

沙发
soporaeternus 发表于 2010-9-9 23:12:28
if flag1=1 or 2 then flag=flag1;
恒成立
所以flag永远是flag1
不会有3
已有 1 人评分学术水平 热心指数 收起 理由
pobel + 1 + 1 我很赞同

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

Let them be hard, but never unjust

藤椅
reolin 发表于 2010-9-9 23:16:14
2# soporaeternus
那应该怎么修改呢,原本应该是flag=3的结果显示为点。

板凳
soporaeternus 发表于 2010-9-9 23:17:46
if flag1=1 or flag1=2 then flag=flag1;
已有 1 人评分学术水平 热心指数 收起 理由
reolin + 1 + 1 一下子就解决了我的困惑。

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

Let them be hard, but never unjust

报纸
reolin 发表于 2010-9-9 23:21:19
4# soporaeternus
高手!!!现在还有一个问题,就是我想把这个flag转换成文本的形式,比如原来是flag1=1,现在我想把它变为flag1='过高值等等',请问该怎么修改了?

地板
soporaeternus 发表于 2010-9-9 23:32:08
  1. proc format;
  2.         value
  3.                 myfmt
  4.                         1="过高值等等"
  5.                         2="过低值等等"
  6.                         3="随便你写什么"
  7.         ;
  8. run;
  9. quit;

  10. data test;
  11.         x=1;
  12.         y=2;
  13.         z=3;
  14.         x1=put(x,myfmt.);
  15.         y1=put(y,myfmt.);
  16.         z1=put(z,myfmt.);

  17. run;
复制代码
一种是直接新建一个变量if flag1=1 then flag2="过高值等等";这样来赋值
还有种就是用format来做
上面给了个例子
希望对你有帮助
已有 1 人评分学术水平 热心指数 收起 理由
reolin + 1 + 1 让我认识了一个新知识。

总评分: 学术水平 + 1  热心指数 + 1   查看全部评分

Let them be hard, but never unjust

7
reolin 发表于 2010-9-9 23:35:51
6# soporaeternus
非常谢谢!!!您已经帮助我解决了好几个问题了,这您们的这些帮助下,我相信我的sas水平会有逐步提升的,谢谢。

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

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