SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 719|回复: 4
打印 上一主题 下一主题

请教如何分组纵向连接字符串?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2011-4-13 14:00:25 | 只看该作者

请教如何分组纵向连接字符串?

示例数据如下:
001    aaa  
001    bbb   
002    ccc   
002    ddd   
002    eee   
003    fff   
想分组纵向合并var1,结果如下所示:
001    aaabbb
002    cccdddeee
003    fff
请问如何实现啊?谢谢!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2011-4-13 14:19:16 | 只看该作者

Re: 请教如何分组纵向连接字符串?

[code:l9i17jmk]data a;
input no$ x$;
cards;
001 aaa
001 bbb
002 ccc
002 ddd
002 eee
003 fff
;
data b(drop=x);
set a;
by no notsorted;
retain y;
if first.no then y=x;
else y=cats(y,x);
if last.no then output;
run;[/code:l9i17jmk]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2011-4-13 18:43:16 | 只看该作者

Re: 请教如何分组纵向连接字符串?

[code:3e3twzmi]data _null_;
    length y $50;
    do _n_=1 by 1 until(last.no);
        set a;
        by no notsorted;
        substr(y,length(y)+1)=x;
    end;
    put no= y=;
run;[/code:3e3twzmi]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2011-4-14 08:19:04 | 只看该作者

Re: 请教如何分组纵向连接字符串?

[code:9xzy241r]proc transpose data = a out = b;
        by no;
        var x;
run;

data b1;
        set b;
        var = cats(of col:);
        drop _: col:;
run;[/code:9xzy241r]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2011-4-14 09:35:27 | 只看该作者

Re: 请教如何分组纵向连接字符串?

非常感谢以上各位!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2025-6-10 14:58 , Processed in 0.070230 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表