楼主: Lotus10
4035 7

[问答] 如何用SAS截取指定数据 [推广有奖]

  • 0关注
  • 0粉丝

硕士生

37%

还不是VIP/贵宾

-

威望
0
论坛币
5228 个
通用积分
4.4650
学术水平
8 点
热心指数
0 点
信用等级
0 点
经验
918 点
帖子
43
精华
0
在线时间
267 小时
注册时间
2015-3-11
最后登录
2023-6-30

20论坛币
求问各位大神,我有如下的数据(数据范例上传在附件中):想要截取其中的回购数量和回购金额的数值形成单独的两列,如何用SAS进行操作???
原始数据.png

即通过截取数据得到如下结果:

处理结果

Sample.xlsx (12.7 KB)


最佳答案

wang_sheng 查看完整内容

先试试,如果不行,就先把Excel里的中文分号';'改成英文逗号',',然后再读进SAS里,然后把scan函数的第3个参数改为英文逗号即可。
沙发
wang_sheng 发表于 2018-10-23 21:25:11 |只看作者 |坛友微信交流群
  1. data result;
  2.         set base_data;
  3.         summary_qty = scan(compress(summary,,'S'),1,';');
  4.         summary_amt= scan(compress(summary,,'S'),2,';');
  5.         qty = compress(summary_qty,,'dk') + 0;
  6.         amt = compress(summary_amt,'.','dk') + 0;
  7. run;
复制代码
先试试,如果不行,就先把Excel里的中文分号';'改成英文逗号',',然后再读进SAS里,然后把scan函数的第3个参数改为英文逗号即可。

使用道具

藤椅
whymath 发表于 2018-10-23 22:27:54 |只看作者 |坛友微信交流群
用merge语句,但是不加By语句。

使用道具

板凳
Lotus10 发表于 2018-10-24 10:02:35 |只看作者 |坛友微信交流群
wang_sheng 发表于 2018-10-23 22:39
先试试,如果不行,就先把Excel里的中文分号';'改成英文逗号',',然后再读进SAS里,然后把scan函数的第3个 ...
data re.re;
set re.repurchase;
    qty1=substr(summary,11,index(summary,'股')-11);
    amt1=substr(summary,index(summary,'回购金额')+10,index(summary,'C')-index(summary,'回购金额')-10);
        run;

想再请教一下,我用上面的方法可以截取第一个回购数量和金额数据,但有的数据是有好几个回购数量和金额,怎么截取后面的呢?

使用道具

报纸
learsaas 发表于 2018-10-24 10:42:57 |只看作者 |坛友微信交流群
把sas数据集上传

使用道具

地板
hgz2373294 发表于 2018-10-24 13:05:07 |只看作者 |坛友微信交流群
SAS +PERL

使用道具

7
Lotus10 发表于 2018-10-24 13:57:06 |只看作者 |坛友微信交流群
wang_sheng 发表于 2018-10-23 22:39
先试试,如果不行,就先把Excel里的中文分号';'改成英文逗号',',然后再读进SAS里,然后把scan函数的第3个 ...
我用一个比较笨的办法处理好了,谢谢你的启发

使用道具

8
BEANJOJO 学生认证  发表于 2021-10-26 12:15:07 来自手机 |只看作者 |坛友微信交流群
Lotus10 发表于 2018-10-24 13:57
我用一个比较笨的办法处理好了,谢谢你的启发
楼主可不可以把你处理的方法发出来,让大家学习学习!

使用道具

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

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

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

GMT+8, 2024-4-19 19:54