How Best to Use Macro Quoting Functions?

Slides:



Advertisements
Similar presentations
1 Jerry Tsai This presentation and code available at: clintuition.com/pubs/
Advertisements

Chapter 9: Introducing Macro Variables 1 © Spring 2012 Imelda Go, John Grego, Jennifer Lasecki and the University of South Carolina.
Macro simple idea of textual substitution useful when you need a group of instructions or directives frequently.
Chapter 3: Editing and Debugging SAS Programs. Some useful tips of using Program Editor Add line number: In the Command Box, type num, enter. Save SAS.
Copyright © 2010 SAS Institute Inc. All rights reserved. SAS ® Macros: Top Ten Questions (and Answers!) Kevin Russell –Technical Support Analyst SAS Institute.
Macro Processor.
Chapter 11: Creating and Using Macro Programs 1 STAT 541 ©Spring 2012 Imelda Go, John Grego, Jennifer Lasecki and the University of South Carolina.
Session 7, Chapter 6 From SAS 9.3 Macro Language Reference Macro Expressions P 71.
Scalar Variables Start the file with: #! /usr/bin/perl –w No spaces or newlines before the the #! “#!” is sometimes called a “shebang”. It is a signal.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 13 - The Preprocessor Outline 13.1Introduction.
1 Chapter 4 Macro Processors Professor Gwan-Hwan Hwang Dept. Computer Science and Information Engineering National Taiwan Normal University 9/17/2009.
Understanding SAS Data Step Processing Alan C. Elliott stattutorials.com.
“SAS macros are just text substitution!” “ARRRRGGHHH!!!”
Copyright © 2008, SAS Institute Inc. All rights reserved. SAS ® Macros: Top-Five Questions (and Answers!) Kim Wilson –Technical Support Analyst SAS Institute.
SCSUG Avoiding Hand Cramps: Name2 macro and arrays for related variables November 9, am South Center SAS Users Group Austin, Texas.
Chapter 10:Processing Macro Variables at Execution Time 1 STAT 541 © Spring 2012 Imelda Go, John Grego, Jennifer Lasecki and the University of South Carolina.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C H A P T E R 2 Input, Processing, and Output.
SAS Macro: Some Tips for Debugging Stat St. Paul’s Hospital April 2, 2007.
INTRODUCTION TO SAS MACRO PROCESSING James R. Bence, Ph.D., Co-Director Quantitative Fisheries Center Professor Department of Fisheries and Wildlife March.
Input, Output, and Processing
5/30/2010 SAS Macro Language Group 6 Pradnya Nimkar, Li Lin, Linsong Zhang & Loc Tran.
_______________________________________________________________________________________________________________ PHP Bible, 2 nd Edition1  Wiley and the.
CPS120: Introduction to Computer Science Functions.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C H A P T E R 2 Input, Processing, and Output.
Strings, output, quotes and comments
Macro Variable Resolution Enio Presutto York University, Toronto, Canada.
Introduction to SAS Macros Center for Statistical Consulting Short Course April 15, 2004.
1 Chapter 3 Syntax, Errors, and Debugging Fundamentals of Java: AP Computer Science Essentials, 4th Edition Lambert / Osborne.
1 © 2000 John Urrutia. All rights reserved. Session 5 The Bourne Shell.
 2008 Pearson Education, Inc. All rights reserved JavaScript: Introduction to Scripting.
CSC 1010 Programming for All Lecture 3 Useful Python Elements for Designing Programs Some material based on material from Marty Stepp, Instructor, University.
Agenda Positional Parameters / Continued... Command Substitution Bourne Shell / Bash Shell / Korn Shell Mathematical Expressions Bourne Shell / Bash Shell.
Chapter 7: Macros in SAS  Macros provide for more flexible programming in SAS  Macros make SAS more “object-oriented”, like R 1 © Fall 2011 John Grego.
Python Let’s get started!.
Compunet Corporation Introduction to Unix (CA263) Round and Round By Tariq Ibn Aziz Dammam Community College.
SAS ® 101 Based on Learning SAS by Example: A Programmer’s Guide Chapter 25 By Tasha Chapman, Oregon Health Authority.
1 Chapter 4 Macro Processors. 2 Introduction A macro instruction (abbreviated to macro) is simply a notational convenience for the programmer. A macro.
Definition of the Programming Language CPRL
Topics Designing a Program Input, Processing, and Output
Chapter 5: Passing and Processing Macro Parameters
Chapter 6 JavaScript: Introduction to Scripting
Python Let’s get started!.
Chapter 13 - The Preprocessor
Variables, Expressions, and IO
Two “identical” programs
Intro to PHP & Variables
What is Bash Shell Scripting?
Conditional Processing
SAS in Data Cleaning.
Chapter 2 – Getting Started
Chapter 7: Macros in SAS Macros provide for more flexible programming in SAS Macros make SAS more “object-oriented”, like R Not a strong suit of text ©
Macro Expressions There are three types of macro expressions: text, logical, and arithmetic. A text expression is any combination of text, macro variables,
Creating Macro Variables and Assigning Value
Lecture 2 Python Programming & Data Types
Creating Macro Variables in the DATA Step
Macro Variable’s scope
Defining and Calling a Macro
Chapter 3: Input/Output
Hunter Glanz & Josh Horstman
Lecture 2 Python Programming & Data Types
Adapted from slides by Nicholas Shahan and Dan Grossman
Passing Simple and Complex Parameters In and Out of Macros
Topics Designing a Program Input, Processing, and Output
Nicholas Shahan Spring 2016
An Introduction to Debugging
Topics Designing a Program Input, Processing, and Output
The Selection Structure
DATA TYPES There are four basic data types associated with variables:
DATA TYPES AND OPERATIONS
PYTHON - VARIABLES AND OPERATORS
Presentation transcript:

How Best to Use Macro Quoting Functions? Arthur Li City of Hope National Medical Center

Intro The macro language is a character-based language. The purpose of using the macro language is used to generate SAS codes. Conflicts: %macro_call, &macro_var; sometimes, & and % signs need to be treated simply as texts The mnemonics, OR or GE, are operators; In some situation, they only need to be interpreted as texts Use the macro quoting functions to mask the special meanings so that the macro processor will be able to interpret them correctly.

Intro %let print_foo = proc print data=foo; run;; %put &print_foo; SAS log: 216 %let print_foo = proc print data=foo; run;; 217 %put &print_foo; proc print data=foo The first semicolon ends the %LET statement; which should be interpreted as plain text.

Intro %let initial = %substr(&name, 1, 1);  %let name = Doe, John; %let initial = %substr(&name, 1, 1); %put &initial; SAS log: 228 %let name = Doe, John; 229 %let initial = %substr(&name, 1, 1); ERROR: Macro function %SUBSTR has too many arguments. 230 %put &initial; %let initial = %substr(&name, 1, 1);  %let initial = %substr(Doe, John, 1, 1);

Macro Quoting Functions Types The macro processor use the macro quoting functions to mask the following characters and mnemonics: & % blank , ; + - * / < > = ┑^ ~ # | ' " ( ) AND OR NOT EQ NE LE LT GE GT IN Compilation and execution quoting functions.

Macro Quoting Functions Types Commonly-used macro quoting functions: %STR, %NRSTR %BQUOTE, %NRBQUOTE %SUPERQ Compilation quoting functions: During the macro compilation phase, using %STR and %NRSTR to treat characters as text in the macro program. Other macro quoting functions are mostly used during the macro execution. During the macro execution, the execution macro functions mask resolved values from macro variables.

Macro Quoting Functions Types The function that begins with NR (non-resolved), such as %NRSTR, masks all the special characters, prevents macro or macro variable resolution. The function that does not begin with NR, such as %STR, masks the special characters except for ampersands (&) and percent signs (%). The functions that with letter B (for “by itself”), such as %BQUOTE and %NRBQUOTE are useful for quoting unmatched quotation marks or parentheses. & % blank , ; + - * / < > = ┑^ ~ # | ' " ( ) AND OR NOT EQ NE LE LT GE GT IN

Compilation Quoting Functions The %STR and %NRSTR functions mask special characters and mnemonics during the macro compilation phase. %STR(character-string) %NRSTR(character-string) The %STR function does not mask & and %. When masking ' " ( ), we need to place a percent sign (%) in front of these characters.

Compilation Quoting Functions Situations: When a user types special characters in the open code, such as in the %LET or %PUT statements. They can also be used in a programming logic statement such as %IF statement. When a user supplies parameter values on a macro call.

The %STR Function %let print_foo = proc print data=foo; run;; %put &print_foo;

The %STR Function Correction: %let print_foo = proc print data=foo; run;; %put &print_foo; Correction: %let print_foo = %str(proc print data=foo; run;); %put &print_foo;

The %STR Function Correction: %let print_foo = proc print data=foo; run;; %put &print_foo; Correction: %let print_foo = %str(proc print data=foo; run;); %put &print_foo; %let print_foo = proc print data=foo%str(;) run%str(;); %put &print_foo; SAS log: 4 %let print_foo = %str(proc print data=foo; run;); 5 %put &print_foo; proc print data=foo; run;

The %STR Function SAS log: %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend;   %first_last(Doe, John) SAS log: 263 %first_last(Doe, John) ERROR: More positional parameters found than defined.

The %STR Function SAS log: Correction: %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend;   %first_last(Doe, John) SAS log: 263 %first_last(Doe, John) ERROR: More positional parameters found than defined. Correction: %first_last(%str(Doe, John))

The %STR Function Use comma(,) as the delimiter: SAS log: %macro first_last1(name); %let first = %scan(&name, 2, ,); %let last = %scan(&name, 1, ,); %put &first &last; %mend; %first_last1(%str(Doe, John)) SAS log: 15 %first_last1(%str(Doe, John)) Doe, John Having two consecutive commas causes %SCAN to use the NULL value as the delimiter

The %STR Function Correction: SAS log: %macro first_last1(name); %let first = %scan(&name, 2, %str(,)); %let last = %scan(&name, 1, %str(,)); %put &first &last; %mend; %first_last1(%str(Doe, John)) SAS log: 36 %first_last1(%str(Doe, John)) John Doe

The %STR Function Preserve the leading blanks in the %PUT statement %macro first_last2(name); %let first = %scan(&name, 2, %str(, )); %let last = %scan(&name, 1, %str(, )); %put %str( &first &last); %mend; %first_last2(%str(Doe, John)) SAS log: 42 %first_last2(%str(Doe, John)) John Doe

The %STR Function SAS log: %macro compare_brand(brand); %if &brand = GE %then %put Brand is General Electric; %else %put Brand is &brand; %mend;   %compare_brand(Coke) SAS log: 50 %compare_brand(Coke) Brand is General Electric

The %STR Function Syntactically correct expression: &brand = GE  %macro compare_brand(brand); %if &brand = GE %then %put Brand is General Electric; %else %put Brand is &brand; %mend;   %compare_brand(Coke) Syntactically correct expression: &brand = GE  ((&brand =) GE)

The %STR Function SAS log: %macro compare_brand1(brand); %if &brand = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand1(Coke) SAS log: 56 %compare_brand1(Coke) Brand is Coke

The %NRSTR Function The %NRSTR function masks all the characters that the %STR function masks. %NRSTR also masks & and %. %let ice_cream = %str(Ben&Jerry); %put &ice_cream; SAS log: 57 %let ice_cream = %str(Ben&Jerry); WARNING: Apparent symbolic reference JERRY not resolved. 58 %put &ice_cream; Ben&Jerry

The %NRSTR Function The %NRSTR function masks all the characters that the %STR function masks. %NRSTR also masks & and %. %let ice_cream = %nrstr(Ben&Jerry); %put &ice_cream; SAS log: 59 %let ice_cream = %nrstr(Ben&Jerry); 60 %put &ice_cream; Ben&Jerry

Situation for using %STR, but not %NRSTR %let printlast = %nrstr(proc print data=&syslast; run;); &printlast SAS log: 731 %let printlast = %nrstr(proc print data=&syslast; run;); 732 &printlast NOTE: Line generated by the macro variable "PRINTLAST". 1 roc print data=&syslast; run; - 22 200 ERROR: File WORK.SYSLAST.DATA does not exist.   ERROR 22-322: Expecting a name. ERROR 200-322: The symbol is not recognized and will be ignored.

Situation for using %STR, but not %NRSTR %let printlast = %nrstr(proc print data=&syslast; run;); &printlast Correction: %let printlast = %str(proc print data=&syslast; run;); &printlast

Execution Quoting Functions The situations for using macro execution quoting functions: Mask the resolved value of a macro variable during macro invocation Mask the result from a macro function or in macro programming logic It is useful to mask the characters that were entered by users but unknown to us and these characters might cause programming errors.

The %BQUOTE and %NRBQUOTE Functions %BQUOTE and %NRBQUOTE: mask special characters and mnemonic operators in a resolved value at macro execution. %BQUOTE(character-string | text-expression) %NRBQUOTE(character-string | text-expression) the %BQUOTE function does not masks ampersand (&) and percent (%) signs

The %BQUOTE and %NRBQUOTE Functions %macro compare_brand1(brand); %if &brand = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand1(GE) SAS log: 315 %compare_brand1(GE) Brand is GE

The %BQUOTE and %NRBQUOTE Functions %macro compare_brand1(brand); %if &brand = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand1(%str(GE)) SAS log: 317 %compare_brand1(%str(GE)) Brand is General Electric

The %BQUOTE and %NRBQUOTE Functions What if we can’t control what the user is going to use when calling the macro? %macro compare_brand2(brand); %if %bquote(&brand) = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand2(GE) SAS log: 333 %compare_brand2(GE) Brand is General Electric

The %BQUOTE and %NRBQUOTE Functions Both methods work: when you mask a special character with a macro quoting function, it remains masked as long as it is within the macro facility %macro compare_brand1(brand); %if &brand = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand1(%str(GE)) %macro compare_brand2(brand); %if %bquote(&brand) = %str(GE) %then %put Brand is General Electric; %else %put Brand is &brand; %mend; %compare_brand2(GE)

The %BQUOTE and %NRBQUOTE Functions %macro addplus1(number); %let first = %substr(&number, 1, 1); %if &first EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if &first NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus1((909)319-2541) %addplus1(1(909)319-2541) %addplus1(%str(+)1(909)319-2541)

The %BQUOTE and %NRBQUOTE Functions SAS log: 365 %addplus1((909)319-2541) +1(909)319-2541 366 %addplus1(1(909)319-2541) 367 %addplus1(%str(+)1(909)319-2541) ERROR: A character operand was found in the %EVAL function or %IF condition where a numeric operand is required. The condition was: &first EQ 1 ERROR: The macro ADDPLUS1 will stop executing.

The %BQUOTE and %NRBQUOTE Functions %macro addplus1(number); %let first = %substr(&number, 1, 1); %if &first EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if &first NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus1(%str(+)1(909)319-2541) The masking applies to “+” sign that is removed when the macro variable is resolved in the %SUBSTR function.

The %BQUOTE and %NRBQUOTE Functions %macro addplus1(number); %let first = %substr(&number, 1, 1); %if &first EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if &first NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus1(%str(+)1(909)319-2541) Incorrect expression: &first EQ 1  + EQ 1

The %BQUOTE and %NRBQUOTE Functions %macro addplus2(number); %let first = %substr(&number, 1, 1); %if %bquote(&first) EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if %bquote(&first) NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus2((909)319-2541) %addplus2(1(909)319-2541) %addplus2(+1(909)319-2541)

The %BQUOTE and %NRBQUOTE Functions SAS log: 380 %addplus2((909)319-2541) +1(909)319-2541 381 %addplus2(1(909)319-2541) 382 %addplus2(+1(909)319-2541)

The %BQUOTE and %NRBQUOTE Functions %NRBQUOTE is similar to %BQUOTE except that the %NRBQUOTE function masks & and % signs in the resolved value of an argument. %macro add_ampersand(number); %let first = %substr(&number, 1, 1); %if %nrbquote(&first) EQ %nrstr(&) %then %do; %let newnumber = &number;; %end; %else %let newnumber =%nrstr(&)&number; %put &newnumber; %mend; %add_ampersand(&123) %add_ampersand(123) 402 %add_ampersand(&123) &123 403 %add_ampersand(123)

The %QUOTE and %NRQUOTE Functions The %QUOTE and %NRQUOTE functions are similar to %BQUOTE and %NRBQUOTE functions. Both of these functions are used during the macro execution phase The %BQUOTE and %NRBQUOTE functions do not require that quotation marks without a match be marked with a preceding % sign, and %QUOTE and %NRQUOTE do. With the availability of the %BQUOTE and %NRBQUOTE functions, the %QUOTE and %NRQUOTE functions are rarely used.

The %SUPERQ Function The %SUPERQ function also masks special characters and mnemonics during macro execution, and it prevents further resolution of the value. %SUPERQ(argument) argument: the name of a macro variable with no leading ampersand. a text expression that produces the name of a macro variable without a leading ampersand. Unlike other macro quoting functions, we can only use the %SUPERQ function to apply on one single macro variable.

The %SUPERQ Function %let name = Doe, John; %let initial = %substr(%superq(name), 1, 1); %put &initial; 404 %let name = Doe, John; 405 %let initial = %substr(%superq(name), 1, 1); 406 %put &initial; D

The %SUPERQ Function The methods above yield the same result. %let name = Doe, John; %let initial = %substr(%superq(name), 1, 1); %put &initial; %let name = %str(Doe, John); %let initial = %substr(&name, 1, 1); %put &initial; %let name = Doe, John; %let initial = %substr(%bquote(&name), 1, 1); %put &initial; The methods above yield the same result.

The %SUPERQ Function Both %NRBQUOTE and %SUPERQ functions mask % and & signs. When using the %NRBQUOTE function, the macro processor masks the argument after the macro processor resolves macro variable references or values. On the other hand, the macro processor masks the argument of the %SUPERQ function before it resolves any macro variable references or values.

The %SUPERQ Function When using the %NRBQUOTE function, the macro processor masks the argument after the macro processor resolves macro variable references or values. data _null_; call symput('ice_cream', 'Ben&Jerry'); run; %let phrase = See you at %nrbquote(&ice_cream); %put &phrase; SAS log: 525 %let phrase = See you at %nrbquote(&ice_cream); WARNING: Apparent symbolic reference JERRY not resolved. 526 %put &phrase; See you at Ben&Jerry

The %SUPERQ Function On the other hand, the macro processor masks the argument of the %SUPERQ function before it resolves any macro variable references or values. data _null_; call symput('ice_cream', 'Ben&Jerry'); run; %let phrase = See you at %superq(ice_cream); %put &phrase; SAS log: 528 %let phrase = See you at %superq(ice_cream); 529 %put &phrase; See you at Ben&Jerry

Quoting Function Results %macro addplus1(number); %let first = %substr(&number, 1, 1); %if &first EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if &first NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus1(%str(+)1(909)319-2541) The masking applies to “+” sign that is removed when the macro variable is resolved in the %SUBSTR function.

Quoting Function Results %macro addplus3(number); %let first = %qsubstr(&number, 1, 1); %if &first EQ 1 %then %do; %let newnumber = +&number;; %end; %else %if &first NE %str(+) %then %do; %let newnumber = +1&number;; %else %let newnumber = &number; %put &newnumber; %mend; %addplus3(%str(+)1(909)319-2541) Alternative method: use %QSUBSTR function to mask the result.

Quoting Function Results %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend; %first_last(%str(O%'Hara, Scarlett)) SAS log: 1772 %first_last(%str(O%'Hara, Scarlett)) ERROR: Literal contains unmatched quote. ERROR: The macro FIRST_LAST will stop executing.

Quoting Function Results %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend; %first_last(%str(O%'Hara, Scarlett)) During the macro execution: &NAME  “O’Hara, Scarlett” in the local symbol table. LOCAL SYMBOL TABLE User-Defined Macro Variables Name O'Hara, Scarlett

Quoting Function Results %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend; %first_last(%str(O%'Hara, Scarlett)) During the macro execution: &First  “Scarlett” in the local symbol table. LOCAL SYMBOL TABLE User-Defined Macro Variables Name O'Hara, Scarlett First Scarlett

Quoting Function Results %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend; %first_last(%str(O%'Hara, Scarlett)) During the macro execution: The macro reference is resolved first The result from the %SCAN function becomes “O’Hara”. The masking applies to the apostrophe that is then removed LOCAL SYMBOL TABLE User-Defined Macro Variables Name O'Hara, Scarlett First Scarlett

Quoting Function Results %macro first_last(name); %let first = %scan(&name, 2); %let last = %scan(&name, 1); %put &first &last; %mend; %first_last(%str(O%'Hara, Scarlett)) During the macro execution: %let last = O'Hara; The semicolon that ends the %LET statement becomes part of the literal. Since there is no ending single quote, the error message is generated. LOCAL SYMBOL TABLE User-Defined Macro Variables Name O'Hara, Scarlett First Scarlett

Quoting Function Results Correction: %macro first_last3(name); %let first = %qscan(&name, 2); %let last = %qscan(&name, 1); %put &first &last; %mend; %first_last3(%str(O%'Hara, Scarlett)) %macro first_last4(name); %let first = %bquote(%scan(&name, 2)); %let last = %bquote(%scan(&name, 1)); %put &first &last; %mend; %first_last4(%str(O%'Hara, Scarlett))

Quoting Function Results *Q equivalent Functions: %QSCAN %QCMPRES %QLEFT %QLOWCASE %QSUBSTR %QTRIM %QUPCASE %QSYSFUNC.

Invisible Characters 574 %put _user_; GLOBAL ICE Ben&Jerry GLOBAL ICE_CREAM Ben&Jerry GLOBAL INITIAL D GLOBAL NAME Doe, John GLOBAL PHRASE See you at _Ben_Jerry_ GLOBAL PRINT_FOO _proc print data_foo_ run__ GLOBAL PRINT_FOO1 proc print data=foo___ run___ GLOBAL WORD BEN&JERRY

Unquoting When special characters or mnemonics are masked, they will be unmasked in the following conditions: They are resolved in the macro functions, such as the %SCAN, %SUBSTR, etc. Generally, they are remained masked as long as they are remained in the macro facility.

Unquoting If the texts are masked, the generated SAS statements appear to be correct, but the compiler often does not recognize them as valid syntax. To explicitly unmask text, use %UNQUOTE %UNQUOTE(character-string | text-expression)

Unquoting data example; input a b c; datalines; 100 200 300 ;   %macro scale(varname); %local i new; data; set example; %do i = 1 %to %sysfunc(countw(&varname)); %let new = %qscan(&varname, &i); val&new = &new/100; %end; run; %mend; %scale(a b)

Unquoting 2108 %scale(a b) NOTE: Line generated by the macro variable "NEW". 1 vala --- 180 1 valb   ERROR 180-322: Statement is not valid or it is used out of proper order. NOTE: The SAS System stopped processing this step because of errors.

Unquoting %macro scale(varname); %local i new; data; set example; %do i = 1 %to %sysfunc(countw(&varname)); %let new = %qscan(&varname, &i); %unquote(val&new) = &new/100; %end; run; %mend;

Conclusion A general rule to choose the correct macro quoting function: If we can see the special character or mnemonics, we need to use the compilation quoting functions. If we cannot see the special character or mnemonics, we need to use the execution quoting functions.

References Burlew, Michele M. 2014, SAS® Macro Programming Made Easy, 3nd Edition, Cary, NC: SAS Institute Inc. Carpenter, Art L., 2006, Carpenter’s Complete Guide to the SAS® Macro Language, 3nd Edition, Cary, NC: SAS Institute Inc. Rosenbloom Mary F. O. and Carpenter, Art L., 2013, “Macro Quoting to the Rescue: Passing Special Characters”, Proceedings of SAS Global Forum 2013. SAS® Macro Language 2: Developing Macro Application Course Notes, 2009, Cary, NC: SAS Institute Inc. Tyndall, Russ, 2014, “Macro Quoting Made Easy”, https://blogs.sas.com/content/sgf/2014/08/15/macro-quoting-made-easy/#prettyPhoto. Whitlock, Ian, “A Serious Look Macro Quoting”, Proceedings of SUGI28.

Acknowledgement I would like to thank Art Carpenter for his valuable programming suggestions and insight.

Contact Information Arthur Li City of Hope National Medical Center Department of Information Science 1500 East Duarte Road Duarte, CA 91010 - 3000 Work Phone: (626) 256-4673 ext. 65121 E-mail: arthurli@coh.org