BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
georgel
Quartz | Level 8

Dear Users, 

I would like to have a prefix before each variable is created instead of _1, _2, _3

when I run the following: (actually BHARced_1 BHARced_2 BHARced_3 and then for the second BHRced_1..

options mprint;
*move the quarters as columns;
%let varlist = BHARced BHRced;

%macro rename;
   %let word_cnt=%sysfunc(countw(&varlist)); 
   %do i = 1 %to &word_cnt; 
     %let temp=%qscan(%bquote(&varlist),&i);
	    proc transpose data=dsf4(keep=cusip year_performance &temp )
					out=performance_&i
					name= &temp;
					id year_performance;
	                *prefix= &name;
					by cusip ;
					
	    run;
        data performance_&i(rename=(_1= 1_&temp _2= 2_&temp _3=3_&temp));/*there is a proble, here*/
		     set performance_&i;
		run;

   %end;
%mend rename;
%rename;

Log output:

MPRINT(RENAME):   proc transpose data=dsf4(keep=cusip year_performance BHARced )
out=performance_1 name= BHARced;
MPRINT(RENAME):   id year_performance;
MPRINT(RENAME):   *prefix= &name;
MPRINT(RENAME):   by cusip ;
MPRINT(RENAME):   run;

NOTE: There were 3301 observations read from the data set WORK.DSF4.
NOTE: The data set WORK.PERFORMANCE_1 has 1186 observations and 5 variables.
NOTE: PROCEDURE TRANSPOSE used (Total process time):
      real time           0.02 seconds
      cpu time            0.00 seconds


214: LINE and COLUMN cannot be determined.
NOTE: NOSPOOL is on. Rerunning with OPTION SPOOL might allow recovery of the LINE and COLUMN
      where the error has occurred.
ERROR 214-322: Variable name 1 is not valid.
NOTE 138-205: Line generated by the macro variable "TEMP".
1     _BHARced
       -------
       79
ERROR 79-322: Expecting a =.

23: LINE and COLUMN cannot be determined.
NOTE 242-205: NOSPOOL is on. Rerunning with OPTION SPOOL might allow recovery of the LINE and
              COLUMN where the error has occurred.
ERROR 23-7: Invalid value for the RENAME option.
MPRINT(RENAME):   data performance_1(rename=(_1= 1_BHARced _2= 2_BHARced _3=3_BHARced));
MPRINT(RENAME):   set performance_1;
MPRINT(RENAME):   run;

NOTE: The SAS System stopped processing this step because of errors.
NOTE: DATA statement used (Total process time):
      real time           0.01 seconds
      cpu time            0.01 seconds


MPRINT(RENAME):   proc transpose data=dsf4(keep=cusip year_performance BHRced ) out=performance_2
name= BHRced;
MPRINT(RENAME):   id year_performance;
MPRINT(RENAME):   *prefix= &name;
MPRINT(RENAME):   by cusip ;
MPRINT(RENAME):   run;

NOTE: There were 3301 observations read from the data set WORK.DSF4.
NOTE: The data set WORK.PERFORMANCE_2 has 1186 observations and 5 variables.
NOTE: PROCEDURE TRANSPOSE used (Total process time):
      real time           0.02 seconds
      cpu time            0.00 seconds


214: LINE and COLUMN cannot be determined.
NOTE: NOSPOOL is on. Rerunning with OPTION SPOOL might allow recovery of the LINE and COLUMN
      where the error has occurred.
ERROR 214-322: Variable name 1 is not valid.
NOTE 138-205: Line generated by the macro variable "TEMP".
1     _BHRced
       ------
       79
ERROR 79-322: Expecting a =.

23: LINE and COLUMN cannot be determined.
NOTE 242-205: NOSPOOL is on. Rerunning with OPTION SPOOL might allow recovery of the LINE and
              COLUMN where the error has occurred.
ERROR 23-7: Invalid value for the RENAME option.
MPRINT(RENAME):   data performance_2(rename=(_1= 1_BHRced _2= 2_BHRced _3=3_BHRced));
MPRINT(RENAME):   set performance_2;
MPRINT(RENAME):   run;

NOTE: The SAS System stopped processing this step because of errors.
NOTE: DATA statement used (Total process time):
      real time           0.01 seconds
      cpu time            0.01 seconds



 

Thank you very much PaigeMiller for your great guidelines

1 ACCEPTED SOLUTION
4 REPLIES 4
PaigeMiller
Diamond | Level 26
/*there is a proble, here*/

 

Whenever code isn't working right, we normally ask to see the LOG. We need to see the ENTIRE log for this macro, every single line, every single character; do not pick and choose parts of the log to show us. Copy the log as text and paste it into the window that appears when you click on the </> icon.

 

2021-11-26 08_27_29-Reply to Message - SAS Support Communities — Mozilla Firefox.png

 

In addition, since it is a macro problem, please run this line and then run your code again and show us that log.

 

options mprint;

 

From now on, we expect you to show us the LOG every single time you have an error or problem.

--
Paige Miller
ballardw
Super User

Prefix option goes into the PROC statement.

This example will PREFIX the name of the variable with ABC before the value of the ID variable.

proc transpose data=sashelp.class(obs=5)
     out =trans prefix=ABC;
   by name;
   var age;
   id sex;
run;

The obs limit is just to make a very small set easy to read.

Tom
Super User Tom
Super User

I suspect that you would be a lot better served to use PROC SUMMARY and the IDGROUP concept to transpose your data since this will allow you to transpose multiple variables at once.

https://support.sas.com/resources/papers/proceedings10/102-2010.pdf

 

 

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
  • 4 replies
  • 2954 views
  • 5 likes
  • 5 in conversation