楼主: gyambqt
1807 4

有偿请教一道程序 [推广有奖]

  • 0关注
  • 0粉丝

高中生

45%

还不是VIP/贵宾

-

威望
0
论坛币
1752 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
1461 点
帖子
18
精华
0
在线时间
15 小时
注册时间
2012-10-25
最后登录
2021-7-7

楼主
gyambqt 发表于 2015-1-14 07:12:08 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
在一组数据里面只有一个变量,一个变量之中有若干email地址有可能出现在一行或者两行或者100行(未知).我希望能够把所有的email地址合并到一行然后删除其他所有合并前的email并保留其它所有非邮件地址的观测值。 例子如下:
(要求用一个data step 实现,不用能proc 或者2个data step)
有偿求教,可以联系我QQ:5231747



原数据

aadsas
basdas
casdas
dsadsa
[邮件地址有可能是一行,两行,两百行。。
...
e@xxx.com a@xxx.com
b@xxx.com c@xxx.com
...
aasdas
sadas
dasdasda
fasdas
gasdas


希望的输出:
aadsas
basdas
casdas
dsadsa
...e@xxx.com a@xxx.comb@xxx.com c@xxx.com...
aasdas
sadas
dasdasda
fasdas
gasdas
二维码

扫码加我 拉你入群

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

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

关键词:Data step Email地址 dasdas Email sadsa email地址 程序

沙发
sushe1527 发表于 2015-1-14 10:11:34
  1. data a;
  2. input a $50.  @@;
  3. if index(a,'@') then a1=1;
  4. cards;
  5. aadsas
  6. basdas
  7. casdas
  8. dsadsa
  9. e@xxx.com a@xxx.com
  10. b@xxx.com c@xxx.com
  11. aasdas
  12. m@xxx.com n@xxx.com k@xxx.com
  13. sadas
  14. dasdasda
  15. fasdas
  16. gasdas
  17. run;

  18. data c1 c2;
  19. set a;
  20. select (a1);
  21. when ('1') output c1;
  22. when ('') output c2;
  23. end;
  24. run;
复制代码


藤椅
gyambqt 发表于 2015-1-14 11:19:44
不对哦,要放在一个table里面不分开,而且邮件是几行你不知道

板凳
gyambqt 发表于 2015-1-14 11:20:18
可以QQ联系 或者其他方式,有偿!!!!

报纸
pobel 在职认证  发表于 2015-1-14 13:32:41
  1. data a;
  2. input a $50.  @@;
  3. cards;
  4. aadsas
  5. basdas
  6. casdas
  7. dsadsa
  8. e@xxx.com a@xxx.com
  9. b@xxx.com c@xxx.com
  10. aasdas
  11. m@xxx.com n@xxx.com k@xxx.com
  12. sadas
  13. dasdasda
  14. fasdas
  15. xxx@bbb.com
  16. gasdas
  17. ;
  18. run;

  19. data wanted;
  20.     length a b $100;
  21.     set a;
  22.         retain flag 1;
  23.         if index(a,"@")=0 then output;
  24.         else if index(a,"@") and flag then do;
  25.        do until( last);
  26.             set a(where=(index(a,"@"))) end=last;
  27.                 b=catx(" ",b,a);
  28.            end;
  29.            a=b; output;
  30.            flag=0;
  31.         end;
  32.         drop b flag;
  33. run;
复制代码

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

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