楼主: lya046
3597 7

[原创博文] 怎样读入数据集并赋值?在线等 [推广有奖]

  • 0关注
  • 0粉丝

高中生

77%

还不是VIP/贵宾

-

威望
0
论坛币
47 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
238 点
帖子
26
精华
0
在线时间
8 小时
注册时间
2009-2-20
最后登录
2010-1-3

楼主
lya046 发表于 2009-8-6 21:30:14 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
现在有一个数据集 ,需要读入每一个数并赋值给新的变量,应该如何做呢?谢谢!
例如:数据集:   col1 col2 col3
                           1       3      5
                           2        4      2
赋值:P1=1, P2=3 ,P3=5
           T1=2, T2=4, T3=2





二维码

扫码加我 拉你入群

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

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

关键词:读入数据 在线等 数据集 在线 如何

回帖推荐

lya046 发表于3楼  查看完整内容

To jingju11 : 就是说把dataset的每个值assign到新的变量, 例如:现有一个数据集: col1 col2 col3 1 3 5 2 4 2 5 7 1 在实现的assignment为:P1=1, P2=3 ,P3=5 T1=2, T2=4, T3=2 ...

本帖被以下文库推荐

沙发
jingju11 发表于 2009-8-6 21:40:11
没有准确地理解你的意思。何谓赋值?

藤椅
lya046 发表于 2009-8-6 21:45:06
To jingju11 :
就是说把dataset的每个值assign到新的变量,
例如:现有一个数据集:   col1 col2 col3
                                          1       3      5
                                          2        4      2
                                           5       7       1
在实现的assignment为:P1=1, P2=3 ,P3=5
                                          T1=2, T2=4, T3=2
                                           H1=5, H2=7, H3=1
已有 1 人评分经验 论坛币 收起 理由
bakoll + 3 + 3 精彩帖子

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

板凳
jingju11 发表于 2009-8-6 21:53:49
如上所示,你的数据集中有3 个变量9 个值;
你需要的是一个数据集,其中只有一行,9个变量(每个变量只有一个值)?
听起来有点怪啊。

报纸
lya046 发表于 2009-8-6 21:57:46
To jingju11 :
     就是这个意思,现在要生成1行有9个变量,怎样才能做到呢?

地板
jingju11 发表于 2009-8-6 22:24:06
data xx;
input col1 col2 col3;
cards;
1  3  5
2  4  2
5  7  1
;
run;
proc transpose data=xx out=yy(drop=_name_);
var col1 col2 col3;
run;
proc transpose data=yy out=zz1 prefix=p;
var col1;
run;
proc transpose data=yy out=zz2 prefix=t;
var col2;
run;
proc transpose data=yy out=zz3 prefix=h;
var col3;
run;
data tot;
merge zz1 zz2 zz3;
drop _name_;
run;

7
lya046 发表于 2009-8-7 00:12:15
To jingju11 :
  十分强大,谢谢谢谢!

8
david0 发表于 2009-8-7 10:12:25
我喜欢用iml来解决这个问题。
proc iml;                                                                                                                              
m=                                                                                                                                      
{1  3  5,                                                                                                                              
2  4  2,                                                                                                                                
5  7  1} ;                                                                                                                              
r=shape(m,1);                                                                                                                           
cname=('p1':'p3')||('t1':'t3')||('h1':'h3');                                                                                            
create newdata from r[colname=cname];                                                                                                   
append from r;                                                                                                                          
quit;                                                                                                                                   
proc print data=newdata; run;

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

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