楼主: Lotus10
4727 7

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

  • 0关注
  • 0粉丝

已卖:619份资源

硕士生

25%

还不是VIP/贵宾

-

威望
0
论坛币
5237 个
通用积分
4.7050
学术水平
8 点
热心指数
0 点
信用等级
0 点
经验
854 点
帖子
24
精华
0
在线时间
267 小时
注册时间
2015-3-11
最后登录
2025-10-17

楼主
Lotus10 发表于 2018-10-23 21:25:10 |AI写论文
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
拉您进交流群
GMT+8, 2026-2-17 15:22