<?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: find all quarters (in form YYMM) between  two dates in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476271#M122537</link>
    <description>&lt;P&gt;It's probably a lot neater to do the work in a data _null_ step and use call symput to establish the macrovars:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%let b=1501;
%let e=1807;

data _null_;
  bdate=mdy(mod(&amp;amp;b,100),1,floor(&amp;amp;b/100));
  edate=mdy(mod(&amp;amp;e,100),1,floor(&amp;amp;e/100));
  do date=intnx('qtr',bdate,0,'end') by 0 while (date&amp;lt;edate);
    t=sum(t,1);
    call symput(cats('T',t),trim(put(date,yymmn4.)));
    date=intnx('qtr',date,1,'end');
  end;
run;
%put _user_;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Sun, 08 Jul 2018 08:29:06 GMT</pubDate>
    <dc:creator>mkeintz</dc:creator>
    <dc:date>2018-07-08T08:29:06Z</dc:date>
    <item>
      <title>find all quarters (in form YYMM) between  two dates</title>
      <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476268#M122536</link>
      <description>&lt;P&gt;Hello&lt;/P&gt;&lt;P&gt;User define two parameters :&amp;nbsp;&lt;/P&gt;&lt;P&gt;%let start=1501; /*Jan 2015*/&lt;/P&gt;&lt;P&gt;%let end=1807;/*July 2018*/&lt;/P&gt;&lt;P&gt;The task is to find all quarters&amp;nbsp;(in form YYMM) between start and end .&lt;/P&gt;&lt;P&gt;In this example &amp;nbsp;we need to get:&lt;/P&gt;&lt;P&gt;1503 (t1)&lt;/P&gt;&lt;P&gt;1506&amp;nbsp;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t2&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1509&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t3&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1512&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t4&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1603&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t5&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1606&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t6&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1609&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t7&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1612&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t8&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1703&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t9&lt;/SPAN&gt;&lt;SPAN&gt;)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1706&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t&lt;/SPAN&gt;&lt;SPAN&gt;10)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1709&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t&lt;/SPAN&gt;&lt;SPAN&gt;11)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1712&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t&lt;/SPAN&gt;&lt;SPAN&gt;12)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1803&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t&lt;/SPAN&gt;&lt;SPAN&gt;13)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;1806&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;(&lt;/SPAN&gt;&lt;SPAN&gt;t&lt;/SPAN&gt;&lt;SPAN&gt;14)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;May anyone suggest how to do it please?&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I wrote this code but I didn't get the correct answer&lt;/P&gt;&lt;P&gt;%let start=1501;&lt;BR /&gt;%let end=1807;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;%let date_start=%sysfunc(inputn(&amp;amp;start.,yymmn4.));&lt;BR /&gt;%let date_end=%sysfunc(inputn(&amp;amp;end.,yymmn4.));&lt;BR /&gt;%put &amp;amp;date_start.;&lt;BR /&gt;%put &amp;amp;date_end.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;/*sas number of quarters between two dates*/&lt;BR /&gt;Data _null_;&lt;BR /&gt;no_of_quarters=intck('QUARTER', &amp;amp;date_start., &amp;amp;date_end.);&lt;BR /&gt;Call Symput("n",no_of_quarters);&lt;BR /&gt;/*call symput("n",trim(left(no_of_quarters)));*/&lt;BR /&gt;Run;&lt;BR /&gt;%put &amp;amp;n.;&lt;/P&gt;&lt;P&gt;%macro months;&lt;BR /&gt;%do j=1 %to &amp;amp;n.;&lt;BR /&gt;t&amp;amp;j.=put(intnx('QUARTER',&amp;amp;date_start.,&amp;amp;j.),yymmn4.);&lt;BR /&gt;call symput("t&amp;amp;j",trim(left(t&amp;amp;j.)));&lt;BR /&gt;%end;&lt;BR /&gt;%mend;&lt;/P&gt;&lt;P&gt;data _null_;&lt;BR /&gt;%months;&lt;BR /&gt;run;&lt;/P&gt;</description>
      <pubDate>Sun, 08 Jul 2018 07:06:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476268#M122536</guid>
      <dc:creator>Ronein</dc:creator>
      <dc:date>2018-07-08T07:06:35Z</dc:date>
    </item>
    <item>
      <title>Re: find all quarters (in form YYMM) between  two dates</title>
      <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476271#M122537</link>
      <description>&lt;P&gt;It's probably a lot neater to do the work in a data _null_ step and use call symput to establish the macrovars:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%let b=1501;
%let e=1807;

data _null_;
  bdate=mdy(mod(&amp;amp;b,100),1,floor(&amp;amp;b/100));
  edate=mdy(mod(&amp;amp;e,100),1,floor(&amp;amp;e/100));
  do date=intnx('qtr',bdate,0,'end') by 0 while (date&amp;lt;edate);
    t=sum(t,1);
    call symput(cats('T',t),trim(put(date,yymmn4.)));
    date=intnx('qtr',date,1,'end');
  end;
run;
%put _user_;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Sun, 08 Jul 2018 08:29:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476271#M122537</guid>
      <dc:creator>mkeintz</dc:creator>
      <dc:date>2018-07-08T08:29:06Z</dc:date>
    </item>
    <item>
      <title>Re: find all quarters (in form YYMM) between  two dates</title>
      <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476272#M122538</link>
      <description>&lt;P&gt;Sorry,Maybe I didn't explain it well&lt;/P&gt;&lt;P&gt;We need to create parameters which are called &amp;nbsp;t1 &amp;nbsp;,t2,t3..etc.&lt;/P&gt;&lt;P&gt;They will get following values&lt;/P&gt;&lt;P&gt;t1=1503&lt;/P&gt;&lt;P&gt;t2=1506&lt;/P&gt;&lt;P&gt;t3=1509&lt;/P&gt;&lt;P&gt;t4=1512&lt;/P&gt;&lt;P&gt;....&lt;/P&gt;&lt;P&gt;t14=1806&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 08 Jul 2018 08:38:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476272#M122538</guid>
      <dc:creator>Ronein</dc:creator>
      <dc:date>2018-07-08T08:38:59Z</dc:date>
    </item>
    <item>
      <title>Re: find all quarters (in form YYMM) between  two dates</title>
      <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476275#M122539</link>
      <description>&lt;P&gt;The code provided by &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31461"&gt;@mkeintz&lt;/a&gt; seems to do what you want. If it does not provide what you want, explain further. What happens when you run the code? Do you get an error? Does it produce the wrong results? Explain!&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;Also, from now on, when you are showing us your code, please click on the running man icon and paste your code into the window that opens.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 08 Jul 2018 14:14:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476275#M122539</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2018-07-08T14:14:17Z</dc:date>
    </item>
    <item>
      <title>Re: find all quarters (in form YYMM) between  two dates</title>
      <link>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476286#M122543</link>
      <description>&lt;P&gt;You don't explain how your attempt failed but it looks like your approach is nearly correct.&amp;nbsp; Your algorithm finds the start of the quarter. But it looks from your required output that you want to find the END of the PREVIOUS quarter.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;It is probably easier to do it all in a data step instead of mixing data steps and macro.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%let start=1501; /*Jan 2015*/
%let end=1807;/*July 2018*/

data _null_;
  start = input("&amp;amp;start",yymmn.);
  end = input("&amp;amp;end",yymmn.);
  do t=1 to intck('qtr',start,end);
    length varname $32 value $10 ;
    varname = cats('T',t) ;
    value = put(intnx('qtr',start,t-1,'e'),yymmn4.) ;
    put varname= value= ;
    call symputx(varname,value);
  end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;You could also do it all in macro code.&amp;nbsp; If you make a separate macro and want to use the generated macro variables then you need to make them GLOBAL so that they will continue to exist after the macro finishes.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%macro make_t(start,end);
%local t varname ;
%let start=%sysfunc(inputn(&amp;amp;start,yymmn));
%let end=%sysfunc(inputn(&amp;amp;end,yymmn));
%do t=1 %to %sysfunc(intck(qtr,&amp;amp;start,&amp;amp;end)) ;
  %let varname=T&amp;amp;t ;
  %global &amp;amp;varname ;
  %let &amp;amp;varname = %sysfunc(intnx(qtr,&amp;amp;start,&amp;amp;t-1,e),yymmn4) ;
  %put &amp;amp;varname = &amp;amp;&amp;amp;&amp;amp;varname ;
%end ;
%mend make_t ;

%let start=1501; /*Jan 2015*/
%let end=1807;/*July 2018*/
%make_t(&amp;amp;start,&amp;amp;end);&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Sun, 08 Jul 2018 14:15:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/find-all-quarters-in-form-YYMM-between-two-dates/m-p/476286#M122543</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2018-07-08T14:15:28Z</dc:date>
    </item>
  </channel>
</rss>

