Hi, I need to convert the current datetime into ddMONyyyybhh:mm:ss format.
For example - if the current time is - 11/10/2015 04:36:12
expected result - 10NOV2015 04:36:12
Tried the below, but need the blank space between year and hour, Please help me..
test=put(datetime(),datetime19.);
There are various ways to do this. Perhaps one of the simplest is to add the following statement after your correct assigment statement:
substr(test,11,1)=' ';As you may have noticed, format datetime19. creates a leading blank. To get rid of that, you could do this:
test=left(put(datetime(),datetime19.));
substr(test,10,1)=' ';
Or this:
test=put(datetime(),datetime19.-l);
substr(test,10,1)=' ';
There are various ways to do this. Perhaps one of the simplest is to add the following statement after your correct assigment statement:
substr(test,11,1)=' ';As you may have noticed, format datetime19. creates a leading blank. To get rid of that, you could do this:
test=left(put(datetime(),datetime19.));
substr(test,10,1)=' ';
Or this:
test=put(datetime(),datetime19.-l);
substr(test,10,1)=' ';
thank u all for the repsonse. Used the substr and it is working.
My understanding is that substr will extract partial text, Could you please explain how it works in this case ?
Thank you for liking and accepting my solution.
There are two different flavors of the SUBSTR function: If it is used to the right of an equals sign, it returns a substring. Left of the equals sign, however, it replaces character value contents. (See the two separate entries for SUBSTR in the online help for more details.) So, in our case it was used to overwrite the first colon in the datetime string with a blank.
data _null_;
date="11/10/2015 4:36:12";
_date=input(date,mdyampm19.);
format _date datetime19.;
put _all_;
run;
Well, you have seen some solutions above, i.e. convert it to text, use an inbuilt format, or create your own. I would ask why you want to do this, what is the purpose of it? If you go with the text variety, then sorting becomes an issue, and you lose the ability to do simple maths on the variable. If you create your own format, then a programmer picking your code up has to look at that format to see what it does (assuming there is no bitness issue on the catalog). Whereas just using the base SAS dates has none of the above issues? Now if its for a report your creating you could hybridise, have a character version and a numeric version, and only display the character one, whilst using the numeric for other processing. Or you could change the report format. Personally I tend to do both of these. In the underlying dataset I would have variables for the necessary calculations, processing, general a date value, and a time value, but sometimes a date/time value. Then there would also be a character version. The reason is that dates have to be complete dates for them to be valid, i.e. day/mon/yr all present and right, but if you have partial dates you may want to display the partials, but not perform calculations, e.g. date=., time="01:00"t; datec="01-2012"; timec="01:00"; datetimec="2012-01---T01:00:00"
You will see in this example I can't do date transformations directyl as date is missing, so would have imputation rules, but I can still do time calculations, and display the data as it is entered or in numeric format. More flexibility in your data means less coding overall.
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.
