<?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: Counting values in sequence by group in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429920#M281542</link>
    <description>&lt;P&gt;ok. do something like this&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Week_end:date9. Cust_id$ Visit_flag;
format Week_end date9.;
datalines;
01JAN2017 01 0
08JAN2017 01 1    
15JAN2017 01 1 
22JAN2017 01 0 
29JAN2017 01 1 
05FEB2017 01 0 
01JAN2017 02 0
08JAN2017 02 1    
15JAN2017 02 1 
22JAN2017 02 1 
29JAN2017 02 1 
05FEB2017 02 0 
;

data temp;
   set have;
   by Cust_id;
   if Visit_flag=0 then seq=0;
   else if Visit_flag then seq+1;
   retain seq;
run;

proc sql;
   create table want as
   select Cust_id
         ,max(seq) as max_seq_visits
   from temp
   group by Cust_id;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 23 Jan 2018 09:25:05 GMT</pubDate>
    <dc:creator>PeterClemmensen</dc:creator>
    <dc:date>2018-01-23T09:25:05Z</dc:date>
    <item>
      <title>Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429914#M281539</link>
      <description>&lt;P&gt;I wanted to count number of visits in a row (each week) for each customer. The problem I'm having is, if I'm using if.first counters, i need to sort the data by the two variables - customer id and a flag whether they visited that week or not. However, I need to keep the data sorted by date and customer id, as I'm interested in sequential observations.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;For example:&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Week_end&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; Cust_id&amp;nbsp; &amp;nbsp; &amp;nbsp; Visit_flag&lt;/P&gt;&lt;P&gt;01JAN2017&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0&lt;BR /&gt;08JAN2017&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&lt;/SPAN&gt;&amp;nbsp;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&lt;/SPAN&gt;&amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;BR /&gt;15JAN2017&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&lt;/SPAN&gt;&amp;nbsp;&lt;BR /&gt;22JAN2017&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0&lt;/SPAN&gt;&amp;nbsp;&lt;BR /&gt;29JAN2017&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&lt;/SPAN&gt;&amp;nbsp;&lt;BR /&gt;05FEB2017&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0&lt;/SPAN&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;01JAN2017&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;08JAN2017&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; 1&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;15JAN2017&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;22JAN2017&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;29JAN2017&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;1&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;05FEB2017&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; 02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;0&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;The output i want, is how many weeks in a row (max) a customer has visited:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Cust_id&amp;nbsp; &amp;nbsp; &amp;nbsp; max_seq_visits&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;01&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;2&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;02&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;4&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks in advance for any help.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:08:43 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429914#M281539</guid>
      <dc:creator>zjanuske</dc:creator>
      <dc:date>2018-01-23T09:08:43Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429918#M281540</link>
      <description>&lt;P&gt;Is there always 1 week between the dates?&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;If U understand you, you want the&amp;nbsp;nunmber of 1s in the longest sequece og 1s by&amp;nbsp;cust_id?&lt;/P&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:18:26 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429918#M281540</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2018-01-23T09:18:26Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429919#M281541</link>
      <description>&lt;P&gt;Yes, there is always 1 week between the dates, and each customer has the same number of weeks assigned to them. And correct - I want the longest sequence of 1s by cust_id,&lt;/P&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:20:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429919#M281541</guid>
      <dc:creator>zjanuske</dc:creator>
      <dc:date>2018-01-23T09:20:47Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429920#M281542</link>
      <description>&lt;P&gt;ok. do something like this&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Week_end:date9. Cust_id$ Visit_flag;
format Week_end date9.;
datalines;
01JAN2017 01 0
08JAN2017 01 1    
15JAN2017 01 1 
22JAN2017 01 0 
29JAN2017 01 1 
05FEB2017 01 0 
01JAN2017 02 0
08JAN2017 02 1    
15JAN2017 02 1 
22JAN2017 02 1 
29JAN2017 02 1 
05FEB2017 02 0 
;

data temp;
   set have;
   by Cust_id;
   if Visit_flag=0 then seq=0;
   else if Visit_flag then seq+1;
   retain seq;
run;

proc sql;
   create table want as
   select Cust_id
         ,max(seq) as max_seq_visits
   from temp
   group by Cust_id;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:25:05 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429920#M281542</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2018-01-23T09:25:05Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429921#M281543</link>
      <description>&lt;P&gt;Post test data in the form of a datastep, as such this is not tested:&lt;/P&gt;
&lt;PRE&gt;data want;
  set have;
  by cust_id;
  retain cnt max_cnt;
  if first.cust_id then do;
    cnt_max=0;
    cnt=0;
  end;
  if flag=1 then cnt=cnt+1;
  else if flag=0 and cnt &amp;gt; 0 then do;
    if cnt &amp;gt; cnt_max then cnt_max=cnt;
    cnt=0;
  end;
run;&lt;/PRE&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:28:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429921#M281543</guid>
      <dc:creator>RW9</dc:creator>
      <dc:date>2018-01-23T09:28:45Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429923#M281544</link>
      <description>&lt;P&gt;That worked out just the way i wanted. Thanks!&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 23 Jan 2018 09:34:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429923#M281544</guid>
      <dc:creator>zjanuske</dc:creator>
      <dc:date>2018-01-23T09:34:29Z</dc:date>
    </item>
    <item>
      <title>Re: Counting values in sequence by group</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429996#M281545</link>
      <description>&lt;P&gt;No problem. If you want to do this in a single data step alone, then do like this&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Week_end:date9. Cust_id$ Visit_flag;
format Week_end date9.;
datalines;
01JAN2017 01 0
08JAN2017 01 1    
15JAN2017 01 1 
22JAN2017 01 0 
29JAN2017 01 1 
05FEB2017 01 0 
01JAN2017 02 0
08JAN2017 02 1    
15JAN2017 02 1 
22JAN2017 02 1 
29JAN2017 02 1 
05FEB2017 02 0 
;

data want(keep=cust_id max_seq_visits);
   set have;
   by cust_id;

   if Visit_flag=0 then cnt=0;
   else if Visit_flag=1 then cnt+1;
   max_seq_visits=ifn(cnt&amp;gt;max_seq_visits, cnt, max_seq_visits);

   if last.cust_id then output;
   retain cnt max_seq_visits;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 23 Jan 2018 14:24:56 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Counting-values-in-sequence-by-group/m-p/429996#M281545</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2018-01-23T14:24:56Z</dc:date>
    </item>
  </channel>
</rss>

