楼主: aucklandsvivian
10361 11

SAS里可以把 0 值替换成missing value吗?求code![已解决] [推广有奖]

  • 0关注
  • 0粉丝

初中生

42%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
171 点
帖子
19
精华
0
在线时间
8 小时
注册时间
2012-12-17
最后登录
2012-12-27

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
想请问在SAS 里生成了一个表格,但是需要把里面为0的值替换成missing value,就是空值。

要怎么办呢??因为数据庞大,88万多行,所以不能导出excel表进行REPLACE。

请教有经验的~~谢谢啦!!

已成功解决!谢谢啦!!
我没有用ARRAY, 我只是用 if then语句。。谢谢大家的指点啦!!

二维码

扫码加我 拉你入群

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

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

关键词:missing value code SSIN alue 怎么办

回帖推荐

a6566792 发表于10楼  查看完整内容

不好意思,之前人在外地, 这里的array _numeric_ 代表所有的数值变量。但是像你这种情况已经知道要处理哪个变量了那就更简单了,code: if _exprat_=0 then _expra3_=.; 就可以了

本帖被以下文库推荐

沙发
a6566792 在职认证  发表于 2012-12-24 12:19:01 |只看作者 |坛友微信交流群
两种情况,0本省就是缺失值:   option missing=‘’;  这样missing就是空值了。
          0本身是个数值:  那就得替换了。if ……then……;
举例:  array s _numeric_;
do over s;
if s=0 then s=.;end;
run;
已有 2 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
数据分析师3K + 20 + 1 + 2 热心帮助其他会员
Imasasor + 24 + 12 + 1 + 1 热心帮助其他会员

总评分: 经验 + 44  论坛币 + 12  学术水平 + 2  热心指数 + 1  信用等级 + 2   查看全部评分

使用道具

藤椅
zkymath 在职认证  发表于 2012-12-25 00:24:59 |只看作者 |坛友微信交流群
简单明了

使用道具

板凳
aucklandsvivian 发表于 2012-12-25 14:37:37 |只看作者 |坛友微信交流群
a6566792 发表于 2012-12-24 12:19
两种情况,0本省就是缺失值:   option missing=‘’;  这样missing就是空值了。
          0本身是个数值 ...
谢谢你!!但是会不会把“0.09”这样的值也被认为是0而改成空值了呢?

使用道具

报纸
aucklandsvivian 发表于 2012-12-25 15:14:14 |只看作者 |坛友微信交流群
a6566792 发表于 2012-12-24 12:19
两种情况,0本省就是缺失值:   option missing=‘’;  这样missing就是空值了。
          0本身是个数值 ...
不好意思我还是不太会用,我不懂什么是s_numeric_ 。。。S是这个表里需要改变0值的那列的名称么?_numeric_是什么呢?我不是说中文意思,是这个为什么要放在s后面不太懂。。

比如我的表名叫a,需要改值的那一列叫b,那应该怎么写呢。。是b_numeric_么。。

我完全不懂这些程序的术语。。见笑了

使用道具

地板
aucklandsvivian 发表于 2012-12-25 16:01:18 |只看作者 |坛友微信交流群
a6566792 发表于 2012-12-24 12:19
两种情况,0本省就是缺失值:   option missing=‘’;  这样missing就是空值了。
          0本身是个数值 ...
data data. exprat3;
array abc _exprat_;
do over abc;
if abc=0 then abc=.;
end;
run;

现在我用的是这个CODE,data.exprat3 is the data set to manipulate, I set abc as the array name, and the _exprat_ is the name of the column which includes 0 value that needs to be turned into a missing value. 我操作之前,data is like this:

1.png

操作这个code之后,他就变成这样了。。。
2.png

请问我是哪里出了问题。。。谢谢了~~~

使用道具

7
a252693398 发表于 2012-12-25 19:13:56 |只看作者 |坛友微信交流群
aucklandsvivian 发表于 2012-12-25 16:01
data data. exprat3;
array abc _exprat_;
do over abc;
程序里面的_numeric_ 代表的数字型的变量 你那个array abc _exprat_ 不对 改成array abc _numeric_

使用道具

8
aucklandsvivian 发表于 2012-12-25 19:42:28 |只看作者 |坛友微信交流群
a252693398 发表于 2012-12-25 19:13
程序里面的_numeric_ 代表的数字型的变量 你那个array abc _exprat_ 不对 改成array abc _numeric_
谢谢!那怎么让它知道我要变动的是那一列的数值呢?我就是不会定义这个ARRAY。。每次都报错

使用道具

9
aucklandsvivian 发表于 2012-12-25 19:45:17 |只看作者 |坛友微信交流群
a252693398 发表于 2012-12-25 19:13
程序里面的_numeric_ 代表的数字型的变量 你那个array abc _exprat_ 不对 改成array abc _numeric_
我刚才试了一下,报错说只有1个observation,0个variable了

使用道具

10
a6566792 在职认证  发表于 2012-12-26 12:19:17 |只看作者 |坛友微信交流群
aucklandsvivian 发表于 2012-12-25 19:45
我刚才试了一下,报错说只有1个observation,0个variable了
不好意思,之前人在外地,  这里的array  _numeric_ 代表所有的数值变量。但是像你这种情况已经知道要处理哪个变量了那就更简单了,code:   if _exprat_=0 then _expra3_=.; 就可以了
已有 1 人评分经验 论坛币 收起 理由
bakoll + 3 + 3 精彩帖子

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

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-11 06:10