<?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: Using hash to aggregate strings in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192593#M36277</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Why?&lt;/P&gt;&lt;P&gt;Do you have a problem with the current solution?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 22 Jan 2015 13:07:13 GMT</pubDate>
    <dc:creator>LinusH</dc:creator>
    <dc:date>2015-01-22T13:07:13Z</dc:date>
    <item>
      <title>Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192592#M36276</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I would like to know how a hash can be used to aggregate character variables across lines. This is, it should be the hash version of this program:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Data A;&lt;BR /&gt;&amp;nbsp; Input Nr N $;&lt;BR /&gt;&amp;nbsp; Datalines;&lt;BR /&gt;1 AA&lt;BR /&gt;1 BB&lt;BR /&gt;2 AA&lt;BR /&gt;2 CC&lt;BR /&gt;2 DD&lt;BR /&gt;3 A_&lt;BR /&gt;3 B_&lt;BR /&gt;3 C_&lt;BR /&gt;;&lt;/P&gt;&lt;P&gt;Data B;&lt;BR /&gt;&amp;nbsp; Length Text $200.;&lt;BR /&gt;&amp;nbsp; Retain Text;&lt;BR /&gt;&amp;nbsp; Do i=1 By 1 Until (Last.Nr);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; Set A;&lt;BR /&gt; By Nr;&lt;BR /&gt; If First.Nr Then Text=N;&lt;BR /&gt; Else Text=Catt(Text,N);&lt;BR /&gt;&amp;nbsp; End;&lt;BR /&gt;Run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thx&amp;amp;kind regards&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 12:47:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192592#M36276</guid>
      <dc:creator>user24feb</dc:creator>
      <dc:date>2015-01-22T12:47:17Z</dc:date>
    </item>
    <item>
      <title>Re: Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192593#M36277</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Why?&lt;/P&gt;&lt;P&gt;Do you have a problem with the current solution?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 13:07:13 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192593#M36277</guid>
      <dc:creator>LinusH</dc:creator>
      <dc:date>2015-01-22T13:07:13Z</dc:date>
    </item>
    <item>
      <title>Re: Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192594#M36278</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Actually, I am playing around a little. However, it is not entirely "fun and games" for me. I have to do this with a great volume of data and a hash might give some speed advantage over the data step (which of course I am not sure of and had to be tested before; I am also aware that SAS is optimized for data steps, but I'd like to try it out; I am also not sure how the hash version could look like).&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 13:17:13 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192594#M36278</guid>
      <dc:creator>user24feb</dc:creator>
      <dc:date>2015-01-22T13:17:13Z</dc:date>
    </item>
    <item>
      <title>Re: Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192595#M36279</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Actually you may not need the Hash. But with Hash, you need not SORT the data set before. See the code below.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data _null_;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if _n_ = 1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; length Text $100;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if 0 then set A;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; declare hash h(ordered:'a');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definekey('Nr');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedata('Nr','Text');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.definedone();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; do until(last);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; set A end = last;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if h.find() ^= 0 then Text = '';&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; call catx('|', Text, N);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; h.replace();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if last then h.output(dataset:'Want');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; stop;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 13:23:35 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192595#M36279</guid>
      <dc:creator>KachiM</dc:creator>
      <dc:date>2015-01-22T13:23:35Z</dc:date>
    </item>
    <item>
      <title>Re: Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192596#M36280</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data b;&lt;/P&gt;&lt;P&gt;length nrn $ 20;&lt;/P&gt;&lt;P&gt;if 0 then set a;&lt;/P&gt;&lt;P&gt;if _n_=1 then &lt;BR /&gt; do;&lt;BR /&gt;&amp;nbsp; declare hash a(dataset:"a", multidata: 'Y');&lt;BR /&gt;&amp;nbsp; a.definekey('nr');&lt;BR /&gt;&amp;nbsp; a.definedata('n');&lt;BR /&gt;&amp;nbsp; a.definedone();&lt;BR /&gt; end;&lt;/P&gt;&lt;P&gt;set a;&lt;BR /&gt;by nr;&lt;/P&gt;&lt;P&gt;if first.nr then do;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if a.find() = 0 then do;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; nrn=n;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; a.has_next(result: r);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do while(r ne 0);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rc = a.find_next();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; nrn=cats(nrn) || n;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; a.has_next(result: r);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;&lt;BR /&gt;output;&lt;BR /&gt;end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 13:28:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192596#M36280</guid>
      <dc:creator>Loko</dc:creator>
      <dc:date>2015-01-22T13:28:07Z</dc:date>
    </item>
    <item>
      <title>Re: Using hash to aggregate strings</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192597#M36281</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;PRE&gt;Data A;
&amp;nbsp; Input Nr N $;
&amp;nbsp; Datalines;
1 AA
1 BB
2 AA
2 CC
2 DD
3 A_
3 B_
3 C_
;
run;
data want;
 if _n_ eq 1 then do;
&amp;nbsp; length text&amp;nbsp; $ 200;
&amp;nbsp; if 0 then set a;
&amp;nbsp; declare hash h();
&amp;nbsp; h.definekey('Nr');
&amp;nbsp; h.definedata('text');
&amp;nbsp; h.definedone();
 end;
set a;
by Nr;
 rc=h.find();
 text=catt(text,N);
 h.replace();
 if last.Nr then do;output;h.clear();end;
 drop n rc;
run;

&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Xia Keshan&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Jan 2015 13:40:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-hash-to-aggregate-strings/m-p/192597#M36281</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2015-01-22T13:40:32Z</dc:date>
    </item>
  </channel>
</rss>

