Hi All,
I have a variable with dates listed in a format of 30.03.2002.
I have tried many options without success.
Here are some commands I have worked with:
new date=input(olddate,date9.);
newdate=input(compress(olddate,'.'),date9.);
newdate= INPUT(compress(olddate),date9.);
format newdate date9.;
Any help would be very much appreciated.
Kind Regards,
Karen
Use format anydtdte :
data test;
dateStr = "30.03.2002";
date = input(dateStr, anydtdte10.);
output;
dateStr = "04.03.2002";
date = input(dateStr, anydtdte10.);
output;
format date date9.;
run;
proc print; run;
PG
To force a correct format, I would avoid the anydtdte10. format, as it may convert some values in an unexpected fashion (03/02/2002: March 2nd or February 3rd?).
Instead use
newdate = input(olddate,ddmmyy10.);
Don't miss out on SAS Innovate - Register now for the FREE Livestream!
Can't make it to Vegas? No problem! Watch our general sessions LIVE or on-demand starting April 17th. Hear from SAS execs, best-selling author Adam Grant, Hot Ones host Sean Evans, top tech journalist Kara Swisher, AI expert Cassie Kozyrkov, and the mind-blowing dance crew iLuminate! Plus, get access to over 20 breakout sessions.
Learn the difference between classical and Bayesian statistical approaches and see a few PROC examples to perform Bayesian analysis in this video.
Find more tutorials on the SAS Users YouTube channel.