楼主: 厌学ing
15345 13

[问答] sas 时间 文本转日期格式的问题 [推广有奖]

  • 3关注
  • 1粉丝

博士生

17%

还不是VIP/贵宾

-

威望
0
论坛币
8 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
6125 点
帖子
173
精华
0
在线时间
262 小时
注册时间
2011-10-15
最后登录
2019-10-15

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
求问:从excel中导入了一堆数据到sas中
时间是文本格式 1990-1-31,
我想用时间函数year()筛选出我想要的年份数据,
直接用不行,要怎么把它改为时间格式的1990-1-31从而能够顺利的使用sas的时间函数呢?

二维码

扫码加我 拉你入群

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

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

关键词:EXCEL exce year sas的 xcel 时间

沙发
webgu 发表于 2013-4-20 10:09:30 |只看作者 |坛友微信交流群
A simple example to use input function and yymmdd10. format:

data _null_;
        string='1990-1-31';
        date=input(string,yymmdd10.);
        put date  yymmdd10.;
run;
SAS资源
1. SAS 微信:StatsThinking
2. SAS QQ群:348941365

使用道具

藤椅
厌学ing 发表于 2013-4-20 18:57:59 |只看作者 |坛友微信交流群
webgu 发表于 2013-4-20 10:09
A simple example to use input function and yymmdd10. format:

data _null_;
谢谢。我试了一下怎么date 出来的是10988呢

使用道具

板凳
Eternal0601 发表于 2013-4-20 19:04:10 |只看作者 |坛友微信交流群
厌学ing 发表于 2013-4-20 18:57
谢谢。我试了一下怎么date 出来的是10988呢
你肯定是创建了数据集,在input语句下面加上 format date  yymmdd10.; 就可以了
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
厌学ing + 1 + 1 + 1 大神啊!

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

使用道具

报纸
厌学ing 发表于 2013-4-20 19:14:54 |只看作者 |坛友微信交流群
厌学ing 发表于 2013-4-20 18:57
谢谢。我试了一下怎么date 出来的是10988呢
就是这样,怎么办呢?

屏幕快照 2013-04-20 07.08.27 PM.png (11.08 KB)

屏幕快照 2013-04-20 07.08.27 PM.png

使用道具

地板
厌学ing 发表于 2013-4-20 19:17:33 |只看作者 |坛友微信交流群
Eternal0601 发表于 2013-4-20 19:04
你肯定是创建了数据集,在input语句下面加上 format date  yymmdd10.; 就可以了
我就是要在数据里面修改的,要怎么做呢?

使用道具

7
厌学ing 发表于 2013-4-20 19:19:20 |只看作者 |坛友微信交流群
Eternal0601 发表于 2013-4-20 19:04
你肯定是创建了数据集,在input语句下面加上 format date  yymmdd10.; 就可以了
哦! 我知道了!成功了!!!!谢谢啊!万分感谢!!!

使用道具

8
厌学ing 发表于 2013-4-20 19:19:22 |只看作者 |坛友微信交流群
Eternal0601 发表于 2013-4-20 19:04
你肯定是创建了数据集,在input语句下面加上 format date  yymmdd10.; 就可以了
哦! 我知道了!成功了!!!!谢谢啊!万分感谢!!!

使用道具

9
Eternal0601 发表于 2013-4-20 19:19:55 |只看作者 |坛友微信交流群
厌学ing 发表于 2013-4-20 19:17
我就是要在数据里面修改的,要怎么做呢?
data raw;
        string='1990-1-31';
run;
data final;
        set raw;
        date=input(string,yymmdd10.);
        format date  yymmdd10.;
run;

使用道具

10
厌学ing 发表于 2013-4-20 21:39:55 |只看作者 |坛友微信交流群
Eternal0601 发表于 2013-4-20 19:19
data raw;
        string='1990-1-31';
run;
yymmdd后面的那个数字是什么意思啊,
我有一个数据集按你说的方法出来的是错的,其他的成功的变成了日期格式的。
错的那个出来的结果是这样的

屏幕快照 2013-04-20 09.28.22 PM.png (11.04 KB)

屏幕快照 2013-04-20 09.28.22 PM.png

使用道具

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

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

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

GMT+8, 2024-4-27 10:01