<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Create multiple macro variables to store totals in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827620#M326927</link>
    <description>&lt;P&gt;This code:&lt;/P&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro totals(no);
	proc sql noprint;
	 select tot into :D&amp;amp;no.A01-:D&amp;amp;no.A11 from _tot where dosenum = "0&amp;amp;no." and trt = 'A';
	 select tot into :D&amp;amp;no.B01-:D&amp;amp;no.B11 from _tot where dosenum = "0&amp;amp;no." and trt = 'B';
	 /*select tot into :D&amp;amp;no.C01-:D&amp;amp;no.C11 from _tot where dosenum = "0&amp;amp;no." and trt = 'C';*/
	 /*select tot into :D&amp;amp;no.D01-:D&amp;amp;no.D11 from _tot where dosenum = "0&amp;amp;no." and trt = 'D';*/
	 /*select tot into :D&amp;amp;no.E01-:D&amp;amp;no.E11 from _tot where dosenum = "0&amp;amp;no." and trt = 'E';*/
	 select tot into :D&amp;amp;no.F01-:D&amp;amp;no.F11 from _tot where dosenum = "0&amp;amp;no." and trt = 'F';
	quit;

%mend;
%totals(1);

%put &amp;amp;=D1A01 &amp;amp;=D1A02 &amp;amp;=D1A03 &amp;amp;=D1A04 &amp;amp;=D1A05 &amp;amp;=D1A06 &amp;amp;=D1A07 &amp;amp;=D1A08 &amp;amp;=D1A09 &amp;amp;=D1A10 &amp;amp;=D1A11
	 &amp;amp;=D1B01 &amp;amp;=D1B02 &amp;amp;=D1B03 &amp;amp;=D1B04 &amp;amp;=D1B05 &amp;amp;=D1B06 &amp;amp;=D1B07 &amp;amp;=D1B08 &amp;amp;=D1B09 &amp;amp;=D1B10 &amp;amp;=D1B11
	 /*&amp;amp;=D1C01 &amp;amp;=D1C02 &amp;amp;=D&amp;amp;no.C03 &amp;amp;=D&amp;amp;no.C04 &amp;amp;=D&amp;amp;no.C05 &amp;amp;=D1C06 &amp;amp;=D&amp;amp;no.C07 &amp;amp;=D&amp;amp;no.C08 &amp;amp;=D&amp;amp;no.C09 &amp;amp;=D&amp;amp;no.C10 &amp;amp;=D&amp;amp;no.C11*/
	 /*&amp;amp;=D1D01 &amp;amp;=D1D02 &amp;amp;=D&amp;amp;no.D03 &amp;amp;=D&amp;amp;no.D04 &amp;amp;=D&amp;amp;no.D05 &amp;amp;=D1D06 &amp;amp;=D&amp;amp;no.D07 &amp;amp;=D&amp;amp;no.D08 &amp;amp;=D&amp;amp;no.D09 &amp;amp;=D&amp;amp;no.D10 &amp;amp;=D&amp;amp;no.D11*/
	 /*&amp;amp;=D1E01 &amp;amp;=D1E02 &amp;amp;=D&amp;amp;no.E03 &amp;amp;=D&amp;amp;no.E04 &amp;amp;=D&amp;amp;no.E05 &amp;amp;=D1E06 &amp;amp;=D&amp;amp;no.E07 &amp;amp;=D&amp;amp;no.E08 &amp;amp;=D&amp;amp;no.E09 &amp;amp;=D&amp;amp;no.E10 &amp;amp;=D&amp;amp;no.E11*/
	 &amp;amp;=D1F01 &amp;amp;=D1F02 &amp;amp;=D1F03 &amp;amp;=D1F04 &amp;amp;=D1F05 &amp;amp;=D1F06 &amp;amp;=D1F07 &amp;amp;=D1F08 &amp;amp;=D1F09 &amp;amp;=D1F10 &amp;amp;=D1F11;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;Is likely making local macro variables, which only exist inside the macro %totals.&amp;nbsp; If you move the %PUT statement into your macro, does it work like you want?&lt;/P&gt;</description>
    <pubDate>Mon, 08 Aug 2022 14:21:28 GMT</pubDate>
    <dc:creator>Quentin</dc:creator>
    <dc:date>2022-08-08T14:21:28Z</dc:date>
    <item>
      <title>Create multiple macro variables to store totals</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827608#M326924</link>
      <description>&lt;P&gt;I need these totals in the report headers for each dose (DOSENUM), treatment (TRT), and study day (STUDYDAY). It should be something like this (one table for each dose-treatment combo):&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="124%"&gt;
&lt;THEAD&gt;
&lt;TR&gt;
&lt;TD rowspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Symptom&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD rowspan="2" width="8%"&gt;
&lt;P&gt;&lt;STRONG&gt;Severity&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Pre-Dose&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Post-Dose&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;1&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;2&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;3&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;4&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;5&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;6&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="7%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;7&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="8%"&gt;
&lt;P&gt;&lt;STRONG&gt;Day&amp;nbsp;8+&lt;BR /&gt;(N=X)&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD colspan="2" width="8%"&gt;
&lt;P&gt;&lt;STRONG&gt;Any Post-Dose*&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="3%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="4%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="4%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="4%"&gt;
&lt;P&gt;&lt;STRONG&gt;n&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;TD width="4%"&gt;
&lt;P&gt;&lt;STRONG&gt;%&lt;/STRONG&gt;&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;/THEAD&gt;
&lt;/TABLE&gt;
&lt;P&gt;The macro variable should fill in the N=X part of the header using PROC REPORT.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;STRONG&gt;Test Data:&lt;/STRONG&gt;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data _dose;
 do dosenum = '01', '02', '03'; output; end;
data _trt;
 do trt = 'A', 'B', 'F'; output; end;
data _stdy;
 do studyday = '00', '00B', '01', '02', '03'; output; end;
run;

proc sql;
 create table _tot0 as
 	select dosenum, trt, studyday
		from _dose, _trt, _stdy;
quit;

data _tot1;
 if _n_ = 0 then set _tot0 nobs= N;
 	do i = 1 to N;
		tot = round(rand("Uniform")*10+1);
		output;
	end;

data _tot;
 merge _tot0 _tot1(keep= tot);
run;

&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&lt;STRONG&gt;Macro + Resulting Warning&lt;/STRONG&gt;&lt;/P&gt;
&lt;PRE&gt;&lt;STRONG&gt;&lt;CODE class=" language-sas"&gt;%macro totals(no);
	proc sql noprint;
	 select tot into :D&amp;amp;no.A01-:D&amp;amp;no.A11 from _tot where dosenum = "0&amp;amp;no." and trt = 'A';
	 select tot into :D&amp;amp;no.B01-:D&amp;amp;no.B11 from _tot where dosenum = "0&amp;amp;no." and trt = 'B';
	 /*select tot into :D&amp;amp;no.C01-:D&amp;amp;no.C11 from _tot where dosenum = "0&amp;amp;no." and trt = 'C';*/
	 /*select tot into :D&amp;amp;no.D01-:D&amp;amp;no.D11 from _tot where dosenum = "0&amp;amp;no." and trt = 'D';*/
	 /*select tot into :D&amp;amp;no.E01-:D&amp;amp;no.E11 from _tot where dosenum = "0&amp;amp;no." and trt = 'E';*/
	 select tot into :D&amp;amp;no.F01-:D&amp;amp;no.F11 from _tot where dosenum = "0&amp;amp;no." and trt = 'F';
	quit;

%mend;
%totals(1);

%put &amp;amp;=D1A01 &amp;amp;=D1A02 &amp;amp;=D1A03 &amp;amp;=D1A04 &amp;amp;=D1A05 &amp;amp;=D1A06 &amp;amp;=D1A07 &amp;amp;=D1A08 &amp;amp;=D1A09 &amp;amp;=D1A10 &amp;amp;=D1A11
	 &amp;amp;=D1B01 &amp;amp;=D1B02 &amp;amp;=D1B03 &amp;amp;=D1B04 &amp;amp;=D1B05 &amp;amp;=D1B06 &amp;amp;=D1B07 &amp;amp;=D1B08 &amp;amp;=D1B09 &amp;amp;=D1B10 &amp;amp;=D1B11
	 /*&amp;amp;=D1C01 &amp;amp;=D1C02 &amp;amp;=D&amp;amp;no.C03 &amp;amp;=D&amp;amp;no.C04 &amp;amp;=D&amp;amp;no.C05 &amp;amp;=D1C06 &amp;amp;=D&amp;amp;no.C07 &amp;amp;=D&amp;amp;no.C08 &amp;amp;=D&amp;amp;no.C09 &amp;amp;=D&amp;amp;no.C10 &amp;amp;=D&amp;amp;no.C11*/
	 /*&amp;amp;=D1D01 &amp;amp;=D1D02 &amp;amp;=D&amp;amp;no.D03 &amp;amp;=D&amp;amp;no.D04 &amp;amp;=D&amp;amp;no.D05 &amp;amp;=D1D06 &amp;amp;=D&amp;amp;no.D07 &amp;amp;=D&amp;amp;no.D08 &amp;amp;=D&amp;amp;no.D09 &amp;amp;=D&amp;amp;no.D10 &amp;amp;=D&amp;amp;no.D11*/
	 /*&amp;amp;=D1E01 &amp;amp;=D1E02 &amp;amp;=D&amp;amp;no.E03 &amp;amp;=D&amp;amp;no.E04 &amp;amp;=D&amp;amp;no.E05 &amp;amp;=D1E06 &amp;amp;=D&amp;amp;no.E07 &amp;amp;=D&amp;amp;no.E08 &amp;amp;=D&amp;amp;no.E09 &amp;amp;=D&amp;amp;no.E10 &amp;amp;=D&amp;amp;no.E11*/
	 &amp;amp;=D1F01 &amp;amp;=D1F02 &amp;amp;=D1F03 &amp;amp;=D1F04 &amp;amp;=D1F05 &amp;amp;=D1F06 &amp;amp;=D1F07 &amp;amp;=D1F08 &amp;amp;=D1F09 &amp;amp;=D1F10 &amp;amp;=D1F11;

WARNING: Apparent symbolic reference D1A01 not resolved.
/*etc.*/&lt;/CODE&gt;&lt;/STRONG&gt;&lt;/PRE&gt;
&lt;P&gt;There is PROC SQL output if I remove the noprint option, but I'm not sure what, if anything, it is storing it as.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Is there a way to see which macro variables I made? I tried %put _all_, but didn't see anything that looked remotely like the name I tried to assign, which leads me to believe it was not storing the variable as a macro at all. In this event, where does my code need adjusting?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 08 Aug 2022 13:46:42 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827608#M326924</guid>
      <dc:creator>mariko5797</dc:creator>
      <dc:date>2022-08-08T13:46:42Z</dc:date>
    </item>
    <item>
      <title>Re: Create multiple macro variables to store totals</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827609#M326925</link>
      <description>&lt;P&gt;Reposting the above macro to look nicer.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro totals(no);
	proc sql noprint;
	 select tot into :D&amp;amp;no.A01-:D&amp;amp;no.A11 from _tot where dosenum = "0&amp;amp;no." and trt = 'A';
	 select tot into :D&amp;amp;no.B01-:D&amp;amp;no.B11 from _tot where dosenum = "0&amp;amp;no." and trt = 'B';
	 /*select tot into :D&amp;amp;no.C01-:D&amp;amp;no.C11 from _tot where dosenum = "0&amp;amp;no." and trt = 'C';*/
	 /*select tot into :D&amp;amp;no.D01-:D&amp;amp;no.D11 from _tot where dosenum = "0&amp;amp;no." and trt = 'D';*/
	 /*select tot into :D&amp;amp;no.E01-:D&amp;amp;no.E11 from _tot where dosenum = "0&amp;amp;no." and trt = 'E';*/
	 select tot into :D&amp;amp;no.F01-:D&amp;amp;no.F11 from _tot where dosenum = "0&amp;amp;no." and trt = 'F';
	quit;

%mend;
%totals(1);

%put &amp;amp;=D1A01 &amp;amp;=D1A02 &amp;amp;=D1A03 &amp;amp;=D1A04 &amp;amp;=D1A05 &amp;amp;=D1A06 &amp;amp;=D1A07 &amp;amp;=D1A08 &amp;amp;=D1A09 &amp;amp;=D1A10 &amp;amp;=D1A11
	 &amp;amp;=D1B01 &amp;amp;=D1B02 &amp;amp;=D1B03 &amp;amp;=D1B04 &amp;amp;=D1B05 &amp;amp;=D1B06 &amp;amp;=D1B07 &amp;amp;=D1B08 &amp;amp;=D1B09 &amp;amp;=D1B10 &amp;amp;=D1B11
	 /*&amp;amp;=D1C01 &amp;amp;=D1C02 &amp;amp;=D&amp;amp;no.C03 &amp;amp;=D&amp;amp;no.C04 &amp;amp;=D&amp;amp;no.C05 &amp;amp;=D1C06 &amp;amp;=D&amp;amp;no.C07 &amp;amp;=D&amp;amp;no.C08 &amp;amp;=D&amp;amp;no.C09 &amp;amp;=D&amp;amp;no.C10 &amp;amp;=D&amp;amp;no.C11*/
	 /*&amp;amp;=D1D01 &amp;amp;=D1D02 &amp;amp;=D&amp;amp;no.D03 &amp;amp;=D&amp;amp;no.D04 &amp;amp;=D&amp;amp;no.D05 &amp;amp;=D1D06 &amp;amp;=D&amp;amp;no.D07 &amp;amp;=D&amp;amp;no.D08 &amp;amp;=D&amp;amp;no.D09 &amp;amp;=D&amp;amp;no.D10 &amp;amp;=D&amp;amp;no.D11*/
	 /*&amp;amp;=D1E01 &amp;amp;=D1E02 &amp;amp;=D&amp;amp;no.E03 &amp;amp;=D&amp;amp;no.E04 &amp;amp;=D&amp;amp;no.E05 &amp;amp;=D1E06 &amp;amp;=D&amp;amp;no.E07 &amp;amp;=D&amp;amp;no.E08 &amp;amp;=D&amp;amp;no.E09 &amp;amp;=D&amp;amp;no.E10 &amp;amp;=D&amp;amp;no.E11*/
	 &amp;amp;=D1F01 &amp;amp;=D1F02 &amp;amp;=D1F03 &amp;amp;=D1F04 &amp;amp;=D1F05 &amp;amp;=D1F06 &amp;amp;=D1F07 &amp;amp;=D1F08 &amp;amp;=D1F09 &amp;amp;=D1F10 &amp;amp;=D1F11;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 08 Aug 2022 13:48:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827609#M326925</guid>
      <dc:creator>mariko5797</dc:creator>
      <dc:date>2022-08-08T13:48:09Z</dc:date>
    </item>
    <item>
      <title>Re: Create multiple macro variables to store totals</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827617#M326926</link>
      <description>&lt;P&gt;Your test data generation is way too complicated, and also is probably not making the values of STUDYDAY you expected because you cannot put the three character string '00B' into a variable you defined to be only 2 bytes long.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data _tot;
  do dosenum = '01', '02', '03'; 
  do trt = 'A', 'B', 'F'; 
  do studyday = '00 ', '00B', '01 ', '02 ', '03 '; 
    tot = round(rand("Uniform")*10+1);
    output; 
  end;
  end;
  end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Use CALL SYMPUTX() to generate the macro variables.&lt;/P&gt;
&lt;P&gt;Here is an example using a macro so I can define the macro variables into an empty symbol table to make it easier to check their values.&amp;nbsp; In real life you don't need the %TEST macro and you probably do not need to force the macro variables into the local symbol table.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro test;
data _null_;
  set _tot;
  call symputx(cats('D',dosenum,trt,studyday),tot,'L');
run;
%put _local_;
%mend test;
%test;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Result:&lt;/P&gt;
&lt;PRE&gt;MPRINT(TEST):   data _null_;
MPRINT(TEST):   set _tot;
MPRINT(TEST):   call symputx(cats('D',dosenum,trt,studyday),tot,'L');
MPRINT(TEST):   run;

NOTE: There were 45 observations read from the data set WORK._TOT.
NOTE: DATA statement used (Total process time):
      real time           0.00 seconds
      cpu time            0.00 seconds


TEST D01A00 10
TEST D01A00B 9
TEST D01A01 8
TEST D01A02 10
TEST D01A03 9
TEST D01B00 5
TEST D01B00B 9
TEST D01B01 9
TEST D01B02 11
TEST D01B03 1
TEST D01F00 2
TEST D01F00B 9
TEST D01F01 10
TEST D01F02 5
TEST D01F03 3
TEST D02A00 7
TEST D02A00B 5
TEST D02A01 4
TEST D02A02 9
TEST D02A03 4
TEST D02B00 7
TEST D02B00B 6
TEST D02B01 6
TEST D02B02 3
TEST D02B03 8
TEST D02F00 6
TEST D02F00B 10
TEST D02F01 9
TEST D02F02 5
TEST D02F03 9
TEST D03A00 2
TEST D03A00B 3
TEST D03A01 8
TEST D03A02 3
TEST D03A03 8
TEST D03B00 6
TEST D03B00B 2
TEST D03B01 6
TEST D03B02 6
TEST D03B03 5
TEST D03F00 10
TEST D03F00B 10
TEST D03F01 2
TEST D03F02 4
TEST D03F03 6
&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 08 Aug 2022 14:15:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827617#M326926</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2022-08-08T14:15:59Z</dc:date>
    </item>
    <item>
      <title>Re: Create multiple macro variables to store totals</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827620#M326927</link>
      <description>&lt;P&gt;This code:&lt;/P&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro totals(no);
	proc sql noprint;
	 select tot into :D&amp;amp;no.A01-:D&amp;amp;no.A11 from _tot where dosenum = "0&amp;amp;no." and trt = 'A';
	 select tot into :D&amp;amp;no.B01-:D&amp;amp;no.B11 from _tot where dosenum = "0&amp;amp;no." and trt = 'B';
	 /*select tot into :D&amp;amp;no.C01-:D&amp;amp;no.C11 from _tot where dosenum = "0&amp;amp;no." and trt = 'C';*/
	 /*select tot into :D&amp;amp;no.D01-:D&amp;amp;no.D11 from _tot where dosenum = "0&amp;amp;no." and trt = 'D';*/
	 /*select tot into :D&amp;amp;no.E01-:D&amp;amp;no.E11 from _tot where dosenum = "0&amp;amp;no." and trt = 'E';*/
	 select tot into :D&amp;amp;no.F01-:D&amp;amp;no.F11 from _tot where dosenum = "0&amp;amp;no." and trt = 'F';
	quit;

%mend;
%totals(1);

%put &amp;amp;=D1A01 &amp;amp;=D1A02 &amp;amp;=D1A03 &amp;amp;=D1A04 &amp;amp;=D1A05 &amp;amp;=D1A06 &amp;amp;=D1A07 &amp;amp;=D1A08 &amp;amp;=D1A09 &amp;amp;=D1A10 &amp;amp;=D1A11
	 &amp;amp;=D1B01 &amp;amp;=D1B02 &amp;amp;=D1B03 &amp;amp;=D1B04 &amp;amp;=D1B05 &amp;amp;=D1B06 &amp;amp;=D1B07 &amp;amp;=D1B08 &amp;amp;=D1B09 &amp;amp;=D1B10 &amp;amp;=D1B11
	 /*&amp;amp;=D1C01 &amp;amp;=D1C02 &amp;amp;=D&amp;amp;no.C03 &amp;amp;=D&amp;amp;no.C04 &amp;amp;=D&amp;amp;no.C05 &amp;amp;=D1C06 &amp;amp;=D&amp;amp;no.C07 &amp;amp;=D&amp;amp;no.C08 &amp;amp;=D&amp;amp;no.C09 &amp;amp;=D&amp;amp;no.C10 &amp;amp;=D&amp;amp;no.C11*/
	 /*&amp;amp;=D1D01 &amp;amp;=D1D02 &amp;amp;=D&amp;amp;no.D03 &amp;amp;=D&amp;amp;no.D04 &amp;amp;=D&amp;amp;no.D05 &amp;amp;=D1D06 &amp;amp;=D&amp;amp;no.D07 &amp;amp;=D&amp;amp;no.D08 &amp;amp;=D&amp;amp;no.D09 &amp;amp;=D&amp;amp;no.D10 &amp;amp;=D&amp;amp;no.D11*/
	 /*&amp;amp;=D1E01 &amp;amp;=D1E02 &amp;amp;=D&amp;amp;no.E03 &amp;amp;=D&amp;amp;no.E04 &amp;amp;=D&amp;amp;no.E05 &amp;amp;=D1E06 &amp;amp;=D&amp;amp;no.E07 &amp;amp;=D&amp;amp;no.E08 &amp;amp;=D&amp;amp;no.E09 &amp;amp;=D&amp;amp;no.E10 &amp;amp;=D&amp;amp;no.E11*/
	 &amp;amp;=D1F01 &amp;amp;=D1F02 &amp;amp;=D1F03 &amp;amp;=D1F04 &amp;amp;=D1F05 &amp;amp;=D1F06 &amp;amp;=D1F07 &amp;amp;=D1F08 &amp;amp;=D1F09 &amp;amp;=D1F10 &amp;amp;=D1F11;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;Is likely making local macro variables, which only exist inside the macro %totals.&amp;nbsp; If you move the %PUT statement into your macro, does it work like you want?&lt;/P&gt;</description>
      <pubDate>Mon, 08 Aug 2022 14:21:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Create-multiple-macro-variables-to-store-totals/m-p/827620#M326927</guid>
      <dc:creator>Quentin</dc:creator>
      <dc:date>2022-08-08T14:21:28Z</dc:date>
    </item>
  </channel>
</rss>

