<?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: How to find unique number in a range of min and max values in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229506#M41541</link>
    <description>Thanks a million Mike. Returns back the results incredibly fast &lt;span class="lia-unicode-emoji" title=":slightly_smiling_face:"&gt;🙂&lt;/span&gt;</description>
    <pubDate>Mon, 12 Oct 2015 08:09:11 GMT</pubDate>
    <dc:creator>Havi</dc:creator>
    <dc:date>2015-10-12T08:09:11Z</dc:date>
    <item>
      <title>How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229252#M41471</link>
      <description>&lt;P&gt;Hi Guys&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I have the dataset 1 below:&lt;/P&gt;
&lt;P&gt;I receive an excel sheet of about 60+ random numbers. How do I read in the sheet and link the unique numbers from EXCEL1 to DATASET 1 to get the&amp;nbsp;account ID i.e OUTPUT 1?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="346"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;DATASET 1&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="124"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;RANGE&lt;/TD&gt;
&lt;TD width="64"&gt;MIN&lt;/TD&gt;
&lt;TD width="64"&gt;MAX&lt;/TD&gt;
&lt;TD width="124"&gt;ACCOUNT_ID&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;High&lt;/TD&gt;
&lt;TD width="64"&gt;1&lt;/TD&gt;
&lt;TD width="64"&gt;10&lt;/TD&gt;
&lt;TD&gt;A0001&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;High&lt;/TD&gt;
&lt;TD width="64"&gt;11&lt;/TD&gt;
&lt;TD width="64"&gt;20&lt;/TD&gt;
&lt;TD&gt;A0002&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;21&lt;/TD&gt;
&lt;TD width="64"&gt;29&lt;/TD&gt;
&lt;TD&gt;A0003&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;30&lt;/TD&gt;
&lt;TD width="64"&gt;69&lt;/TD&gt;
&lt;TD&gt;A0004&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;70&lt;/TD&gt;
&lt;TD width="64"&gt;99&lt;/TD&gt;
&lt;TD&gt;A0005&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;100&lt;/TD&gt;
&lt;TD width="64"&gt;299&lt;/TD&gt;
&lt;TD&gt;A0006&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;300&lt;/TD&gt;
&lt;TD width="64"&gt;499&lt;/TD&gt;
&lt;TD&gt;A0007&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Medium&lt;/TD&gt;
&lt;TD width="64"&gt;500&lt;/TD&gt;
&lt;TD width="64"&gt;1000&lt;/TD&gt;
&lt;TD&gt;A0008&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Low&lt;/TD&gt;
&lt;TD width="64"&gt;1001&lt;/TD&gt;
&lt;TD width="64"&gt;1499&lt;/TD&gt;
&lt;TD&gt;A0009&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Low&lt;/TD&gt;
&lt;TD width="64"&gt;1500&lt;/TD&gt;
&lt;TD width="64"&gt;2000&lt;/TD&gt;
&lt;TD&gt;A0010&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Very Low&lt;/TD&gt;
&lt;TD width="64"&gt;2001&lt;/TD&gt;
&lt;TD width="64"&gt;6000&lt;/TD&gt;
&lt;TD&gt;A0011&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;Very Low&lt;/TD&gt;
&lt;TD width="64"&gt;6001&lt;/TD&gt;
&lt;TD width="64"&gt;9000&lt;/TD&gt;
&lt;TD&gt;A0012&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE width="346"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;EXCEL1&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="124"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;NUMBERS&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="124"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;10&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;2005&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;8000&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&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;TABLE width="346"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;OUTPUT1&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="124"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;NUMBER&lt;/TD&gt;
&lt;TD width="64"&gt;&lt;SPAN&gt;ACCOUNT_ID&lt;/SPAN&gt;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD width="124"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;10&lt;/TD&gt;
&lt;TD width="64"&gt;&lt;SPAN&gt;A0001&lt;/SPAN&gt;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;2005&lt;/TD&gt;
&lt;TD width="64"&gt;&lt;SPAN&gt;A0011&lt;/SPAN&gt;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="94"&gt;8000&lt;/TD&gt;
&lt;TD width="64"&gt;&lt;SPAN&gt;A0012&lt;/SPAN&gt;&lt;/TD&gt;
&lt;TD width="64"&gt;&amp;nbsp;&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;Many thanks&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 11:50:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229252#M41471</guid>
      <dc:creator>Havi</dc:creator>
      <dc:date>2015-10-09T11:50:24Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229254#M41472</link>
      <description>&lt;P&gt;&amp;nbsp;Use SQL join with a between - and criteria.&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 11:53:43 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229254#M41472</guid>
      <dc:creator>LinusH</dc:creator>
      <dc:date>2015-10-09T11:53:43Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229279#M41482</link>
      <description>&lt;P&gt;Presumably, you know how to read in the sheet. &amp;nbsp;If not, that's a separate question.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I would create a format out of the min/max ranges:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data fmt;&lt;/P&gt;
&lt;P&gt;fmtname='$acct';&lt;/P&gt;
&lt;P&gt;set dataset1 end=done;&lt;/P&gt;
&lt;P&gt;length label $ 7;&lt;/P&gt;
&lt;P&gt;rename min=start max=end;&lt;/P&gt;
&lt;P&gt;label=account;&lt;/P&gt;
&lt;P&gt;output;&lt;/P&gt;
&lt;P&gt;if done;&lt;/P&gt;
&lt;P&gt;hlo='O';&lt;/P&gt;
&lt;P&gt;label='Unknown';&lt;/P&gt;
&lt;P&gt;output;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;proc format cntlin=fmt;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Then it becomes easy to look up the values:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data want;&lt;/P&gt;
&lt;P&gt;set excel1;&lt;/P&gt;
&lt;P&gt;account_id = put(number, $acct.);&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;It's untested, but should work. &amp;nbsp;Good luck.&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 13:23:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229279#M41482</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2015-10-09T13:23:49Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229283#M41484</link>
      <description>&lt;P&gt;&lt;BR /&gt;proc sql;&lt;BR /&gt;create table Want as &lt;BR /&gt;select A.Number, B.Account_Id from Numbers1 A left join Dataset1 B &lt;BR /&gt;on B.Min le A.Number le B.Max;&lt;BR /&gt;quit;&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 13:38:36 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229283#M41484</guid>
      <dc:creator>MadhuKorni</dc:creator>
      <dc:date>2015-10-09T13:38:36Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229325#M41499</link>
      <description>&lt;P&gt;Thanks MadhuKorni&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Would this be the most optimal way? The reason I am asking is that although the numbers table is small with 60 records the left join to the dataset1 table is around 40 million records?&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 16:02:26 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229325#M41499</guid>
      <dc:creator>Havi</dc:creator>
      <dc:date>2015-10-09T16:02:26Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229366#M41511</link>
      <description>&lt;P&gt;Hi, this works with the data you posted (assumes you'll have a match for all obs in data set SEARCH) ...&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data x;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;input range :$6. min max account :$5. @@;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;datalines;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;High 1 10 A0001&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;High 11 20 A0002&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 21 29 A0003&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 30 69 A0004 &lt;/STRONG&gt;&lt;/FONT&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 70 99 A0005&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 100 299 A0006&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 300 499 A0007&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Medium 500 1000 A0008 &lt;/STRONG&gt;&lt;/FONT&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT size="2"&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Low 1001 1499 A0009&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Low 1500 2000 A0010&amp;nbsp;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;VeryLow 2001 6000 A0011 &lt;/STRONG&gt;&lt;/FONT&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;VeryLow 6001 9000 A0012 &lt;/STRONG&gt;&lt;/FONT&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;input number @@;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;datalines;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;10 2005 8000&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data y (keep=number account);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;set search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;do until (number ge min and number le max);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; set x;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;end;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;run;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data set Y ...&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;Obs&amp;nbsp;&amp;nbsp;&amp;nbsp; number&amp;nbsp;&amp;nbsp;&amp;nbsp; account&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 10&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; A0001&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 2005&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; A0011&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 8000&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; A0012&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 20:30:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229366#M41511</guid>
      <dc:creator>MikeZdeb</dc:creator>
      <dc:date>2015-10-09T20:30:59Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229378#M41512</link>
      <description>&lt;P&gt;Hi, try 40 million observations (&amp;lt;2 seconds) ..&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data x;&lt;BR /&gt;do account=1 to 40e6;&lt;BR /&gt;&amp;nbsp; min = 10*account;&lt;BR /&gt;&amp;nbsp; max = min + 9;&lt;BR /&gt;&amp;nbsp; output;&lt;BR /&gt;end;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;input number :comma. @@;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;datalines;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;10 2005 99,999,999 300,000,000 999,999,999&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;* won't find last number ... too big;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data y (keep=number account);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;set search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;do until (number ge min and number le max);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; set x;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;end;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;273&amp;nbsp; data y (keep=number account);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;274&amp;nbsp; set search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;275&amp;nbsp; do until (number ge min and number le max);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;276&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; set x;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;277&amp;nbsp; end;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;278&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;279&amp;nbsp; run;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;NOTE: There were 5 observations read from the data set WORK.SEARCH.&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;NOTE: There were 40000000 observations read from the data set WORK.X.&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;NOTE: The data set WORK.Y has 4 observations and 2 variables.&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;NOTE: DATA statement used (Total process time):&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; real time&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1.38 seconds&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; cpu time&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 1.34 seconds&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;</description>
      <pubDate>Fri, 09 Oct 2015 21:13:25 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229378#M41512</guid>
      <dc:creator>MikeZdeb</dc:creator>
      <dc:date>2015-10-09T21:13:25Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229394#M41513</link>
      <description>&lt;P&gt;Mike,&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Very nice approach. &amp;nbsp;It can be expanded to cover additional situations. &amp;nbsp;Perhaps, for example, two NUMBER values belong to the same account. &amp;nbsp;You might go with:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data want;&lt;/P&gt;
&lt;P&gt;set search;&lt;/P&gt;
&lt;P&gt;if (min &amp;lt;= number &amp;lt;= max) then return;&lt;/P&gt;
&lt;P&gt;do until (min &amp;lt;= number &amp;lt;= max);&lt;/P&gt;
&lt;P&gt;&amp;nbsp; &amp;nbsp;set x;&lt;/P&gt;
&lt;P&gt;end;&lt;/P&gt;
&lt;P&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;And there is always the more complex possibility that you mentioned: &amp;nbsp;What if one NUMBER does not have a match (a decimal fraction perhaps?) but the next NUMBER does have a match? &amp;nbsp;WIthout sketching out all the details, it would probably be easiest to create two output data sets (one holding matches, one holding mismatches).&lt;/P&gt;</description>
      <pubDate>Sat, 10 Oct 2015 00:50:56 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229394#M41513</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2015-10-10T00:50:56Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229438#M41523</link>
      <description>&lt;P&gt;Hi ...&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;re &lt;EM&gt;duplicates in the SEARCH data set&lt;/EM&gt; (if SEARCH in order) ...&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;data y (keep=number account);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;set search;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;if number ne lag(number);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;do until (number ge min and number le max);&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;&amp;nbsp;&amp;nbsp; set x;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;end;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;BR /&gt;&lt;FONT face="courier new,courier"&gt;&lt;STRONG&gt;run;&amp;nbsp;&lt;/STRONG&gt;&lt;/FONT&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;FONT face="arial,helvetica,sans-serif"&gt;re "&lt;EM&gt;more complex possibility&lt;/EM&gt;"&amp;nbsp;... life is full of them&lt;/FONT&gt;&lt;/P&gt;</description>
      <pubDate>Sat, 10 Oct 2015 15:49:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229438#M41523</guid>
      <dc:creator>MikeZdeb</dc:creator>
      <dc:date>2015-10-10T15:49:29Z</dc:date>
    </item>
    <item>
      <title>Re: How to find unique number in a range of min and max values</title>
      <link>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229506#M41541</link>
      <description>Thanks a million Mike. Returns back the results incredibly fast &lt;span class="lia-unicode-emoji" title=":slightly_smiling_face:"&gt;🙂&lt;/span&gt;</description>
      <pubDate>Mon, 12 Oct 2015 08:09:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/How-to-find-unique-number-in-a-range-of-min-and-max-values/m-p/229506#M41541</guid>
      <dc:creator>Havi</dc:creator>
      <dc:date>2015-10-12T08:09:11Z</dc:date>
    </item>
  </channel>
</rss>

