<?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: Flag when variable is closer to one in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671768#M201775</link>
    <description>&lt;P&gt;Thanks&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31304"&gt;@PeterClemmensen&lt;/a&gt;&amp;nbsp; and&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/10892"&gt;@PaigeMiller&lt;/a&gt;&amp;nbsp;for your quick response.&lt;BR /&gt;Take this data for example please.&lt;BR /&gt;So I need to flag=Y when varX is closest to one by id and varZ.&lt;BR /&gt;Thanks in advance.&lt;/P&gt;
&lt;TABLE width="247"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="54"&gt;id&amp;nbsp;&lt;/TD&gt;
&lt;TD width="66"&gt;varX&lt;/TD&gt;
&lt;TD width="65"&gt;varZ&lt;/TD&gt;
&lt;TD width="62"&gt;flag&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;50&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;4&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;10&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;4&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;-1&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;6&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;</description>
    <pubDate>Thu, 23 Jul 2020 11:22:36 GMT</pubDate>
    <dc:creator>Miracle</dc:creator>
    <dc:date>2020-07-23T11:22:36Z</dc:date>
    <item>
      <title>Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671749#M201758</link>
      <description>&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;Dear All,&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;How do I flag=Y when varX is closet to one by id and varZ please?&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;Thanks in advance.&lt;/FONT&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 23 Jul 2020 10:45:09 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671749#M201758</guid>
      <dc:creator>Miracle</dc:creator>
      <dc:date>2020-07-23T10:45:09Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671751#M201760</link>
      <description>&lt;P&gt;Show us your data &lt;span class="lia-unicode-emoji" title=":slightly_smiling_face:"&gt;🙂&lt;/span&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 23 Jul 2020 10:48:42 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671751#M201760</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2020-07-23T10:48:42Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671763#M201772</link>
      <description>&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/16719"&gt;@Miracle&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;How do I flag=Y when varX is closet to one by id and varZ please?&lt;/FONT&gt;&lt;/P&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;Please explain this further. Provide more details. Show us an example.&lt;/P&gt;</description>
      <pubDate>Thu, 23 Jul 2020 11:07:56 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671763#M201772</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2020-07-23T11:07:56Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671768#M201775</link>
      <description>&lt;P&gt;Thanks&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31304"&gt;@PeterClemmensen&lt;/a&gt;&amp;nbsp; and&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/10892"&gt;@PaigeMiller&lt;/a&gt;&amp;nbsp;for your quick response.&lt;BR /&gt;Take this data for example please.&lt;BR /&gt;So I need to flag=Y when varX is closest to one by id and varZ.&lt;BR /&gt;Thanks in advance.&lt;/P&gt;
&lt;TABLE width="247"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="54"&gt;id&amp;nbsp;&lt;/TD&gt;
&lt;TD width="66"&gt;varX&lt;/TD&gt;
&lt;TD width="65"&gt;varZ&lt;/TD&gt;
&lt;TD width="62"&gt;flag&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;50&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;4&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;1&lt;/TD&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;10&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;A&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;4&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;-1&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;Y&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;6&lt;/TD&gt;
&lt;TD&gt;C&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;</description>
      <pubDate>Thu, 23 Jul 2020 11:22:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671768#M201775</guid>
      <dc:creator>Miracle</dc:creator>
      <dc:date>2020-07-23T11:22:36Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671771#M201776</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data two;
     set one;
     distance = abs(varX - 1);
run;
proc summary data=two nway;
     class id varz;
     var distance;
    output out=_stats_ min=min_distance;
run;
data want;
     merge two _stats_;
     by id varz;
     if distance=min_distance than flag="Y";
run;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 23 Jul 2020 11:31:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671771#M201776</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2020-07-23T11:31:07Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671791#M201786</link>
      <description>&lt;P&gt;My 2 cents.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Is there a reason why the row&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="247"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;2&lt;/TD&gt;
&lt;TD&gt;3&lt;/TD&gt;
&lt;TD&gt;B&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;should not be flagged&lt;SPAN&gt;?&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input id varX varZ $;
datalines;
1 1  A
1 50 A
1 1  B
1 4  B
1 3  C
1 2  C
2 10 A
2 3  A
2 3  A
2 3  B
2 4  B
2 -1 B
2 3  C
2 6  C
;


data want(drop=mdist);
   do _N_ = 1 by 1 until (last.varZ);
      set have;
      by id varZ;
      mdist = min(mdist, abs(1 - varX));
   end;

   do _N_ = 1 to _N_;
      set have;
      flag = ifc(abs(1 - varX) = mdist, "Y", "");
      output;
   end;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Result&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;id varX varZ flag 
1  1    A    Y 
1  50   A      
1  1    B    Y 
1  4    B      
1  3    C      
1  2    C    Y 
2  10   A      
2  3    A    Y 
2  3    A    Y 
2  3    B    Y 
2  4    B      
2  -1   B    Y 
2  3    C    Y 
2  6    C      
&lt;/PRE&gt;</description>
      <pubDate>Thu, 23 Jul 2020 12:31:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671791#M201786</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2020-07-23T12:31:24Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671834#M201802</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;A solution with proc sql :&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql noprint;
    CREATE TABLE want AS
    SELECT *, CASE WHEN abs(varX-1)=min(abs(varX-1)) THEN "Y" END AS Flag
    FROM have
    GROUP BY id, varZ
    ;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 23 Jul 2020 14:35:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/671834#M201802</guid>
      <dc:creator>gamotte</dc:creator>
      <dc:date>2020-07-23T14:35:11Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/672458#M202116</link>
      <description>&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;Thanks&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31304"&gt;@PeterClemmensen&lt;/a&gt;&amp;nbsp; for the sharp eye.&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="andale mono,times" size="4"&gt;You are absolutely right!&amp;nbsp;&lt;/FONT&gt;&lt;/P&gt;</description>
      <pubDate>Mon, 27 Jul 2020 06:18:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/672458#M202116</guid>
      <dc:creator>Miracle</dc:creator>
      <dc:date>2020-07-27T06:18:29Z</dc:date>
    </item>
    <item>
      <title>Re: Flag when variable is closer to one</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/672460#M202117</link>
      <description>&lt;P&gt;&lt;FONT face="andale mono,times" size="4"&gt;Thanks&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/10892"&gt;@PaigeMiller&lt;/a&gt;,&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31304"&gt;@PeterClemmensen&lt;/a&gt;&amp;nbsp; and&amp;nbsp;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/30622"&gt;@gamotte&lt;/a&gt;&amp;nbsp; for all your solutions! Much appreciate it&amp;nbsp;&lt;/FONT&gt;&lt;span class="lia-unicode-emoji" title=":grinning_face:"&gt;😀&lt;/span&gt;&lt;/P&gt;</description>
      <pubDate>Mon, 27 Jul 2020 06:32:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Flag-when-variable-is-closer-to-one/m-p/672460#M202117</guid>
      <dc:creator>Miracle</dc:creator>
      <dc:date>2020-07-27T06:32:35Z</dc:date>
    </item>
  </channel>
</rss>

