<?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: creating D02-D05 from D02;D03;D04;D05 and more complicated things in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40673#M8312</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; Here is another variation using the LAG function:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length newvar $100 _subvar $5;&lt;/P&gt;&lt;P&gt;_isincrement = 0;&lt;/P&gt;&lt;P&gt;do _i = 1 by 1 until ( missing( _subvar ) );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _subvar = scan( var, _i, ';' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _prefix = compress( _subvar,, 'ka' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagprefix = lag( _prefix );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _suffix = compress( _subvar,, 'kd' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagsuffix = lag( _suffix );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagsubvar = lag( _subvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if _prefix = _lagprefix and _suffix = _lagsuffix + 1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _isincrement = 1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; else do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if _isincrement then newvar = catx( '-', newvar, _lagsubvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; newvar = catx( ';', newvar, _subvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _isincrement = 0;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 23 Mar 2012 14:12:43 GMT</pubDate>
    <dc:creator>FloydNevseta</dc:creator>
    <dc:date>2012-03-23T14:12:43Z</dc:date>
    <item>
      <title>creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40666#M8305</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 have a variable separated by ;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Examples :&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05;&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;&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become D01-D05&lt;/P&gt;&lt;P&gt;D01;D02;D03;D05;&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;&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become D01-D03;D05&lt;/P&gt;&lt;P&gt;D10;D11;D12;D13;D17;D20;D21;D22&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become D10-D13;D17;D20-D22;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Any help to get me on my way?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks!&amp;nbsp; &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Mar 2012 15:01:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40666#M8305</guid>
      <dc:creator>Filipvdr</dc:creator>
      <dc:date>2012-03-22T15:01:28Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40667#M8306</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Following code can also applied to more general condition, such as: D01;E01;&lt;/P&gt;&lt;P&gt;Limitation: Can only work on 3-character substring like this: D01; while it can be tweaked to accomodate more complex scenarios.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input var $40.;&lt;/P&gt;&lt;P&gt;datalines4;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05; &lt;/P&gt;&lt;P&gt;D01;D02;D03;D05;E01;F01;F02; &lt;/P&gt;&lt;P&gt;D10;D11;D12;D13;D17;D20;D21;D22;&lt;/P&gt;&lt;P&gt;;;;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length _var VarFinal $40.;&lt;/P&gt;&lt;P&gt;do _i=1 by 1 until (missing (scan(var,_i,';')));&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _i=1 then _sv=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv1=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv2=scan(var,_i+1,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if (first(_mv1) ne first(_mv2) or substr(_mv2,2,2)-substr(_mv1,2,2)&amp;gt;1) then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt; if _sv = _mv1 then _var=_sv;&lt;/P&gt;&lt;P&gt; else _var=catx('-',_sv,_mv1);&lt;/P&gt;&lt;P&gt; _sv=_mv2;&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt; if not missing(_var) then varFinal=catx(';',varFinal,_var);&lt;/P&gt;&lt;P&gt; call missing(_var);&lt;/P&gt;&lt;P&gt;end; &lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc print;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;Haikuo&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Mar 2012 16:40:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40667#M8306</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-03-22T16:40:29Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40668#M8307</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Here is one version that can be used for more general conditions, such as undefined length of substrings, undefined number of character or digits within the substrings.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input var $ 60.;&lt;/P&gt;&lt;P&gt;datalines4;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05;AA101;AA102;AA103; &lt;/P&gt;&lt;P&gt;D01;D02;D03;D05;E01;F01;F02; &lt;/P&gt;&lt;P&gt;D10;D11;D12;D13;D17;D20;D21;D22;&lt;/P&gt;&lt;P&gt;;;;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length _var VarFinal $100.;&lt;/P&gt;&lt;P&gt;do _i=1 by 1 until (missing (scan(var,_i,';')));&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _i=1 then _sv=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv1=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mc1=compress(_mv1,,'ka');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mn1=compress(_mv1,,'kd');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv2=scan(var,_i+1,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mc2=compress(_mv2,,'ka');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mn2=compress(_mv2,,'kd');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if (_mc1 ne _mc2 or _mn2-_mn1&amp;gt;1) then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt; if _sv = _mv1 then _var=_sv;&lt;/P&gt;&lt;P&gt; else _var=catx('-',_sv,_mv1);&lt;/P&gt;&lt;P&gt; _sv=_mv2;&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt; if not missing(_var) then varFinal=catx(';',varFinal,_var);&lt;/P&gt;&lt;P&gt; call missing(_var);&lt;/P&gt;&lt;P&gt;end; &lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc print;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Mar 2012 17:05:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40668#M8307</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-03-22T17:05:19Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40669#M8308</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Going further, here is another more general approach which works on unsorted substrings with the same variable:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input var $ 60.;&lt;/P&gt;&lt;P&gt;datalines4;&lt;/P&gt;&lt;P&gt;AA103;D01;D05;D03;D04;D02;AA101;AA102; &lt;/P&gt;&lt;P&gt;F01;D02;D03;D05;E01;D01;F02; &lt;/P&gt;&lt;P&gt;D1000;D11;D22;D13;D17;D20;D21;D12;&lt;/P&gt;&lt;P&gt;;;;;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select max(countw(var)) into :num from have;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;filename new_v "h:\temp\new_v.txt";&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data _null_ ;&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;file new_v;&lt;/P&gt;&lt;P&gt;array v $10 _v1-_v%sysevalf(&amp;amp;num+1);&lt;/P&gt;&lt;P&gt;do _i=1 by 1 until (missing (scan(var,_i,';')));&lt;/P&gt;&lt;P&gt; v(_i)=scan(var,_i,';');&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt; call sortc(of v(*));&lt;/P&gt;&lt;P&gt;put v(*);&lt;/P&gt;&lt;P&gt; run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt; data want (drop=_:) ;&lt;/P&gt;&lt;P&gt; infile new_v;&lt;/P&gt;&lt;P&gt; length _var VarFinal $100.;&lt;/P&gt;&lt;P&gt; input var : &amp;amp; $300.;&lt;/P&gt;&lt;P&gt; do _i=1 by 1 until (missing (scan(var,_i)));&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _i=1 then _sv=scan(var,_i);&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv1=scan(var,_i);&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mc1=compress(_mv1,,'ka');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mn1=compress(_mv1,,'kd');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv2=scan(var,_i+1);&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mc2=compress(_mv2,,'ka');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mn2=compress(_mv2,,'kd');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if (_mc1 ne _mc2 or abs(_mn2-_mn1)&amp;gt;1 ) then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt; if _sv = _mv1 then _var=_sv;&lt;/P&gt;&lt;P&gt; else _var=catx('-',_sv,_mv1);&lt;/P&gt;&lt;P&gt; _sv=_mv2;&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt; if not missing(_var) then varFinal=catx(';',varFinal,_var);&lt;/P&gt;&lt;P&gt; call missing(_var);&lt;/P&gt;&lt;P&gt;end; &lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc print;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 22 Mar 2012 18:36:52 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40669#M8308</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-03-22T18:36:52Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40670#M8309</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; thanks for all your answers&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I have to calculate a second variable now:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I have the same strings:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05;&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;&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become DDDDD&lt;/P&gt;&lt;P&gt;D01;D02;D03;D05;&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;&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become DDD-D&lt;/P&gt;&lt;P&gt;D10;D11;D12;D13;D17;D20;D21;D22&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; should become ---------DDDD---D--DDD;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 09:12:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40670#M8309</guid>
      <dc:creator>Filipvdr</dc:creator>
      <dc:date>2012-03-23T09:12:47Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40671#M8310</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Question:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The '-' in between groups, is it always just one? or quantiy of '-'s reflects the size of the gap?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 11:51:50 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40671#M8310</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-03-23T11:51:50Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40672#M8311</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; the - reflects the size of the gap, so for each number that is not in the row there is a - &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 12:33:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40672#M8311</guid>
      <dc:creator>Filipvdr</dc:creator>
      <dc:date>2012-03-23T12:33:07Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40673#M8312</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; Here is another variation using the LAG function:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length newvar $100 _subvar $5;&lt;/P&gt;&lt;P&gt;_isincrement = 0;&lt;/P&gt;&lt;P&gt;do _i = 1 by 1 until ( missing( _subvar ) );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _subvar = scan( var, _i, ';' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _prefix = compress( _subvar,, 'ka' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagprefix = lag( _prefix );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _suffix = compress( _subvar,, 'kd' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagsuffix = lag( _suffix );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagsubvar = lag( _subvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if _prefix = _lagprefix and _suffix = _lagsuffix + 1 then do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _isincrement = 1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; else do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if _isincrement then newvar = catx( '-', newvar, _lagsubvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; newvar = catx( ';', newvar, _subvar );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _isincrement = 0;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; end;&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 14:12:43 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40673#M8312</guid>
      <dc:creator>FloydNevseta</dc:creator>
      <dc:date>2012-03-23T14:12:43Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40674#M8313</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I see you already have an answer. Anyway, if pursuing the same logic that I have applied on the previous ones, here is one solution:&lt;/P&gt;&lt;P&gt;This only applied to the same character scenario, as I don't know your rules about transits between , say D02 to FF03, if there are such things in real life.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input var $40.;&lt;/P&gt;&lt;P&gt;datalines4;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D05;&lt;/P&gt;&lt;P&gt;D10;D11;D12;D13;D17;D20;D21;D22;&lt;/P&gt;&lt;P&gt;;;;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length&amp;nbsp; VarFinal $40.;&lt;/P&gt;&lt;P&gt;do _i=1 by 1 until (missing (scan(var,_i,';')));&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _i=1 then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _sv=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; _svc=substr(_sv,1,1);&lt;/P&gt;&lt;P&gt; VarFinal=_svc;&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv1=scan(var,_i,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _mv2=scan(var,_i+1,';');&lt;/P&gt;&lt;P&gt;&amp;nbsp; _m21=substr(_mv2,2,2)-substr(_mv1,2,2);&lt;/P&gt;&lt;P&gt;&amp;nbsp; if _m21=1 then Varfinal=cats(Varfinal,_svc);&lt;/P&gt;&lt;P&gt;&amp;nbsp; else if _m21&amp;gt;1 then&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do;&lt;/P&gt;&lt;P&gt; do _k=1 by 1 to (_m21-1);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; VarFinal=cats(VarFinal,'-');&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;VarFinal=cats(VarFinal,_svc);&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt; end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc print;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 14:35:17 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40674#M8313</guid>
      <dc:creator>Haikuo</dc:creator>
      <dc:date>2012-03-23T14:35:17Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40675#M8314</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;This one is actually easier than the original problem.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input var $ 60.;&lt;/P&gt;&lt;P&gt;datalines4;&lt;/P&gt;&lt;P&gt;D01;D02;D03;D04;D05; &lt;/P&gt;&lt;P&gt;D01;D02;D03;D05; &lt;/P&gt;&lt;P&gt;A10;A11;A12;A13;A17;A20;A21;A22;&lt;/P&gt;&lt;P&gt;;;;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data want (drop=_:);&lt;/P&gt;&lt;P&gt;set have;&lt;/P&gt;&lt;P&gt;length newvar $100 _subvar $5 _gapchar $100;&lt;/P&gt;&lt;P&gt;do _i = 1 by 1 until ( missing( _subvar ) );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _subvar = scan( var, _i, ';' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _prefix = compress( _subvar,, 'ka' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _suffix = compress( _subvar,, 'kd' );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _lagsuffix = lag( _suffix );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _gapchar = '';&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; * check for gap;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; _gap = _suffix - coalesce(_lagsuffix,0) - 1;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if _gap &amp;gt; 0 then _gapchar = repeat( '-', _gap-1 );&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; newvar = cats( newvar, _gapchar, _prefix );&lt;/P&gt;&lt;P&gt;end;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 23 Mar 2012 14:48:12 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40675#M8314</guid>
      <dc:creator>FloydNevseta</dc:creator>
      <dc:date>2012-03-23T14:48:12Z</dc:date>
    </item>
    <item>
      <title>Re: creating D02-D05 from D02;D03;D04;D05 and more complicated things</title>
      <link>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40676#M8315</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt; I prefer to Linlin's solution.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE&gt;data have;
input var $40.;
datalines4;
D01;D02;D03;D04;D05;
D01;D02;D03;D05;
D10;D11;D12;D13;D17;D20;D21;D22;
;;;;
run;
data temp1(keep=group d num);
 set have;
 group+1;
&amp;nbsp; i=1;
&amp;nbsp; d=substr(scan(var,i,';'),1,1);
&amp;nbsp; num=input(substr(scan(var,i,';'),2),best8.);
&amp;nbsp; do while(not missing(d));
&amp;nbsp;&amp;nbsp; output;
&amp;nbsp;&amp;nbsp; i+1;
&amp;nbsp;&amp;nbsp; d=substr(scan(var,i,';'),1,1);
&amp;nbsp;&amp;nbsp; num=input(substr(scan(var,i,';'),2),best8.);
&amp;nbsp; end;
run;
proc sort data=temp1;by group num;run;
data temp2(keep=group num);
 set temp1(rename=(num=_num));
 by group;
 if last.group then do;
&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; do num=1 to _num;
&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;&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; output;
&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; end;
&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;end;
run;
data x;
 merge temp1 temp2;
 by group num; 
 if missing(d) then d='-';
run;
data want(keep=have want);
 set x;
 by group;
 length have want $ 400;
 retain have want;
 if first.group then call missing(want,have);
 if d ne '-' then have=catx(';',have,cats(d,num));
 want=cats(want,d);
 if last.group then output;
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;Ksharp&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 25 Mar 2012 03:10:22 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/creating-D02-D05-from-D02-D03-D04-D05-and-more-complicated/m-p/40676#M8315</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2012-03-25T03:10:22Z</dc:date>
    </item>
  </channel>
</rss>

