<?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 when first row in a group doesn't match other rows in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767971#M243533</link>
    <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;

data have;
input (Case_id	Country) (:$15.);
cards;
12456789	unknown
12456789	Mexico
12456789	unknown
56789	unknown
56789	Cuba
56789	USA
777 Mexico
777 Mexico
777 unknown
;


data want;
 set have;
 by case_id;
 retain t;
 if first.case_id then if country='unknown' then t=1;
 else t=.;
 if t and  country ne 'unknown';
 drop t;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Wed, 15 Sep 2021 18:52:00 GMT</pubDate>
    <dc:creator>novinosrin</dc:creator>
    <dc:date>2021-09-15T18:52:00Z</dc:date>
    <item>
      <title>Find when first row in a group doesn't match other rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767929#M243515</link>
      <description>&lt;P&gt;I need to find when the first row within a group, grouping by case_id, has a value of unknown for the variable country but any of the other rows within a group have a known value.&amp;nbsp; Below is an example of the data that I would be starting with.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Case_id&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Country&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;12456789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;unknown&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;12456789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Mexico&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;12456789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;unknown&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;56789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;unknown&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;56789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Cuba&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;56789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;USA&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;output I would want:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Case_id&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Country&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;12456789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Mexico&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;56789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Cuba&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;56789&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;USA&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Wed, 15 Sep 2021 16:33:20 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767929#M243515</guid>
      <dc:creator>jk2018</dc:creator>
      <dc:date>2021-09-15T16:33:20Z</dc:date>
    </item>
    <item>
      <title>Re: Find when first row in a group doesn't match other rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767932#M243518</link>
      <description>&lt;P&gt;That seems to just filter out all unknowns.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Is there a case where you'd keep a different record?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
set have;
where country ne 'unknown';
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/66157"&gt;@jk2018&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;I need to find when the first row within a group, grouping by case_id, has a value of unknown for the variable country but any of the other rows within a group have a known value.&amp;nbsp; Below is an example of the data that I would be starting with.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;Case_id&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Country&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;12456789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;unknown&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;12456789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Mexico&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;12456789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;unknown&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;56789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;unknown&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;56789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Cuba&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;56789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;USA&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;output I would want:&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;Case_id&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Country&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;12456789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Mexico&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;56789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;Cuba&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;
&lt;P&gt;56789&lt;/P&gt;
&lt;/TD&gt;
&lt;TD&gt;
&lt;P&gt;USA&lt;/P&gt;
&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&lt;BR /&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Wed, 15 Sep 2021 16:36:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767932#M243518</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2021-09-15T16:36:48Z</dc:date>
    </item>
    <item>
      <title>Re: Find when first row in a group doesn't match other rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767963#M243530</link>
      <description>&lt;P&gt;If the first observation for each case_id does not equal unknown then I need all the observations for that case_id to be excluded from the output.&amp;nbsp; For example, if a record like this was in the dataset I would not want it in the final dataset:&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;Case_id&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Country&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;777&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Mexico&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;777&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;Mexico&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&lt;P&gt;777&lt;/P&gt;&lt;/TD&gt;&lt;TD&gt;&lt;P&gt;unknown&lt;/P&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Wed, 15 Sep 2021 18:19:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767963#M243530</guid>
      <dc:creator>jk2018</dc:creator>
      <dc:date>2021-09-15T18:19:36Z</dc:date>
    </item>
    <item>
      <title>Re: Find when first row in a group doesn't match other rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767971#M243533</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;

data have;
input (Case_id	Country) (:$15.);
cards;
12456789	unknown
12456789	Mexico
12456789	unknown
56789	unknown
56789	Cuba
56789	USA
777 Mexico
777 Mexico
777 unknown
;


data want;
 set have;
 by case_id;
 retain t;
 if first.case_id then if country='unknown' then t=1;
 else t=.;
 if t and  country ne 'unknown';
 drop t;
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Wed, 15 Sep 2021 18:52:00 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767971#M243533</guid>
      <dc:creator>novinosrin</dc:creator>
      <dc:date>2021-09-15T18:52:00Z</dc:date>
    </item>
    <item>
      <title>Re: Find when first row in a group doesn't match other rows</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767983#M243540</link>
      <description>&lt;P&gt;Delete the unknown observations when they are not the only observation.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
  input Case_id :$10. Country :$20.;
cards;
12456789 unknown
12456789 Mexico
12456789 unknown
56789 unknown
56789 Cuba
56789 USA
9999 unknown
;

data want ;
  set have;
  by case_id ;
  if country='unknown' and not (first.case_id and last.case_id) then delete;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;PRE&gt;Obs    Case_id     Country

 1     12456789    Mexico
 2     56789       Cuba
 3     56789       USA
 4     9999        unknown


&lt;/PRE&gt;</description>
      <pubDate>Wed, 15 Sep 2021 19:31:05 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Find-when-first-row-in-a-group-doesn-t-match-other-rows/m-p/767983#M243540</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2021-09-15T19:31:05Z</dc:date>
    </item>
  </channel>
</rss>

