楼主: liuchang1989
1587 2

字符转date格式老出错 [推广有奖]

  • 1关注
  • 2粉丝

讲师

32%

还不是VIP/贵宾

-

威望
0
论坛币
736 个
通用积分
0.0026
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
4038 点
帖子
425
精华
0
在线时间
462 小时
注册时间
2010-4-27
最后登录
2017-4-10

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
我的date 是比如像 01jan1987 05jan1987 这样的字符
我想产生一个新变量转化为SAS DATE格式  于是我用了下面的函数

Date1=mdy(substr(Date,3,3),substr(Date,1,2),substr(Date,6,4));
format Date1 yymmdd10.;


结果显示的Date1 全是空缺值

提示:NOTE: Invalid numeric data, 'jan' , at line 9 column 20.


不知该如何处理?谢谢各位!
二维码

扫码加我 拉你入群

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

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

关键词:date ATE numeric invalid SUBSTR

沙发
Eternal0601 发表于 2014-12-2 21:13:23 |只看作者 |坛友微信交流群
mdy function要求每个参数为数值,substr(Date,3,3)返回的为jan,为字符,所以结果为空值

10   data _null_;
11       a='01jan2014';
12       b=input(a,date9.);
13       format b date9.;
14       put _all_;
15   run;

a=01jan2014 b=01JAN2014 _ERROR_=0 _N_=1

使用道具

藤椅
liuchang1989 发表于 2014-12-3 18:55:15 |只看作者 |坛友微信交流群
Eternal0601 发表于 2014-12-2 21:13
mdy function要求每个参数为数值,substr(Date,3,3)返回的为jan,为字符,所以结果为空值

10   data _nu ...
明白了  多谢这位朋友!

使用道具

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

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

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

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