BookmarkSubscribeRSS Feed
dyxdyx
Calcite | Level 5

Hello,

 

I would like to convert a character variable (called Month_Year) into a date variable. It has a MM/YYYY format, e.g. 06/1986 corresponds to June 1986.

 

I have tried the following statements but didn't work:

 

informat Month_Year mmyys10.;

Date = input(Month_Year, mmyys10.);

 

Can anyone help?

7 REPLIES 7
art297
Opal | Level 21

The following will work:

 

data have;
  input cdate $;
  cards;
06/1986
;

data want;
  set have;
  format date date9.;
  date=input(cdate,anydtdte7.);
run;

Art, CEO, AnalystFinder.com

 

dyxdyx
Calcite | Level 5

Hi art297,

 

Thanks for your reply. Your code works but with a small problem - it added a day value to MM/YYYY.  e.g. it turned 06/1986 into 01JUN1986. Is it possible to convert into a date variable that has only month and year (no day) info in SAS? Does SAS have a date format that only has info on month and year?

 

Thanks again.

dyxdyx
Calcite | Level 5

Thanks!

 

One follow up question - I tried to do this in one statement:

date1=input(date, mmyy10.);

 

but the error message says "The informat MMYY was not fuond or could not be loaded."

 

I ended up having to do this in two statements:

  date1=input(date,anydtdte7.);
  format date1 mmyy10.;

 

Why can't the input function accept mmyy10.?

 

Thanks!!

Tom
Super User Tom
Super User

The assignment statement and the FORMAT statement are doing differnt things. The first is setting the value of a variable and the second is changing the metadata about the variable.

You still need to use a FORMAT statement if you want to attach a format to a variable.

 

There is no INFORMAT named MMYY.  That is why you need to use the ANYDTDTE. informat.

 

dyxdyx
Calcite | Level 5

Thanks! This makes sense.

Tom
Super User Tom
Super User

You can't have a date without a day.  You can attach a format that only show the year and the month.

101  data _null_;
102    date = '01JUN1986'd ;
103    do fmt = 'YYMMDD10.','YYMM7.','YYMMS7.','MMYY7.','MMYYS7.';
104       str=putn(date,fmt);
105       put fmt= str= ;
106    end;
107  run;

fmt=YYMMDD10. str=1986-06-01
fmt=YYMM7. str=1986M06
fmt=YYMMS7. str=1986/06
fmt=MMYY7. str=06M1986
fmt=MMYYS7. str=06/1986

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

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.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 7 replies
  • 28893 views
  • 1 like
  • 3 in conversation