BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
BonnaryW
Obsidian | Level 7

Hello,

 

I need help on how to add previous QTR to the filename.  My code is below.

ods _all_ close;

%let q= (%sysfunc(intnx(qtr,%sysfunc(date()),-1)));

%put &q;

ods tagsets.excelxp file="c:\myfile_Q&q..xls"

style=sasweb;

 

My filename should be "c:\myfile_Q2.xls. I am getting "c:\myfile_Q&q.xls".

 

Thank you.

1 ACCEPTED SOLUTION

Accepted Solutions
Reeza
Super User

Macro variables are literal text replacement. I see the %PUT statement but it doesn't generate what you expect so that's where your error is. 

 

Your PUT statement shows:

(21275)

 

You're creating a SAS date but don't apply a format. For Q# format try QTR format, which can be applied directly in SYSFUNC. You also have extraneous parenthesis.

 

%let q= %sysfunc(intnx(qtr,%sysfunc(date()),-1), qtr.);

@BonnaryW wrote:

Hello,

 

I need help on how to add previous QTR to the filename.  My code is below.

ods _all_ close;

%let q= (%sysfunc(intnx(qtr,%sysfunc(date()),-1)));

%put &q;

ods tagsets.excelxp file="c:\myfile_Q&q..xls"

style=sasweb;

 

My filename should be "c:\myfile_Q2.xls. I am getting "c:\myfile_Q&q.xls".

 

Thank you.


 

View solution in original post

1 REPLY 1
Reeza
Super User

Macro variables are literal text replacement. I see the %PUT statement but it doesn't generate what you expect so that's where your error is. 

 

Your PUT statement shows:

(21275)

 

You're creating a SAS date but don't apply a format. For Q# format try QTR format, which can be applied directly in SYSFUNC. You also have extraneous parenthesis.

 

%let q= %sysfunc(intnx(qtr,%sysfunc(date()),-1), qtr.);

@BonnaryW wrote:

Hello,

 

I need help on how to add previous QTR to the filename.  My code is below.

ods _all_ close;

%let q= (%sysfunc(intnx(qtr,%sysfunc(date()),-1)));

%put &q;

ods tagsets.excelxp file="c:\myfile_Q&q..xls"

style=sasweb;

 

My filename should be "c:\myfile_Q2.xls. I am getting "c:\myfile_Q&q.xls".

 

Thank you.


 

sas-innovate-wordmark-2025-midnight.png

Register Today!

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

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
  • 1 reply
  • 768 views
  • 0 likes
  • 2 in conversation