<?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 Splitting rows into multiple columns based on a mix of chars and strings ('and', '+', '&amp;amp;', etc) in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483180#M125276</link>
    <description>&lt;P&gt;Hi!&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Trying to figure out how to split rows into multiple rows based on words or characters in a variable.&amp;nbsp; Searched but didn't find anything that mixed text and chars as a solution....&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;fname in data below contains 'and', '+', '&amp;amp;' , 'and not' as the words to split the rows.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data homes;&lt;BR /&gt;length fname $100 lname $19 addr $38 city $20 state $2 zip 8;&lt;BR /&gt;infile cards dlm="|" ;&lt;BR /&gt;input fname $ lname $ addr $ city $ state $ zip;&lt;BR /&gt;cards;&lt;BR /&gt;Raggedy Anne and Andy|Family|In The Attic|DC|DC|20007&lt;BR /&gt;Batman + Robin|Superduders|The Batcave|Gotham|NY|10012&lt;BR /&gt;Jack &amp;amp; Jill|Smith|123 Uphill Rd|Alma|CO|80420&lt;/P&gt;
&lt;P&gt;Ernie but not Bert|Muppet|Sesame Street|NY|NY|10128&lt;/P&gt;
&lt;P&gt;;&lt;BR /&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;want:&lt;/P&gt;
&lt;TABLE width="1014"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="169"&gt;fname&lt;/TD&gt;
&lt;TD width="169"&gt;lname&lt;/TD&gt;
&lt;TD width="169"&gt;addr&lt;/TD&gt;
&lt;TD width="169"&gt;city&lt;/TD&gt;
&lt;TD width="169"&gt;state&lt;/TD&gt;
&lt;TD width="169"&gt;zip&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Raggedy Anne&lt;/TD&gt;
&lt;TD&gt;Family&lt;/TD&gt;
&lt;TD&gt;In The Attic&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;20007&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Andy&lt;/TD&gt;
&lt;TD&gt;Family&lt;/TD&gt;
&lt;TD&gt;In The Attic&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;20007&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Batman&lt;/TD&gt;
&lt;TD&gt;Superduders&lt;/TD&gt;
&lt;TD&gt;The Batcave&lt;/TD&gt;
&lt;TD&gt;Gotham&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10012&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Robin&lt;/TD&gt;
&lt;TD&gt;Superduders&lt;/TD&gt;
&lt;TD&gt;The Batcave&lt;/TD&gt;
&lt;TD&gt;Gotham&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10012&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Jack&lt;/TD&gt;
&lt;TD&gt;Smith&lt;/TD&gt;
&lt;TD&gt;123 Uphill Rd&lt;/TD&gt;
&lt;TD&gt;Alma&lt;/TD&gt;
&lt;TD&gt;CO&lt;/TD&gt;
&lt;TD&gt;80420&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Jill&lt;/TD&gt;
&lt;TD&gt;Smith&lt;/TD&gt;
&lt;TD&gt;123 Uphill Rd&lt;/TD&gt;
&lt;TD&gt;Alma&lt;/TD&gt;
&lt;TD&gt;CO&lt;/TD&gt;
&lt;TD&gt;80420&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Ernie&lt;/TD&gt;
&lt;TD&gt;Muppet&lt;/TD&gt;
&lt;TD&gt;Sesame Street&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10128&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Bert&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;Muppet&lt;/TD&gt;
&lt;TD&gt;Sesame Street&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10128&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&lt;BR /&gt;I've gotten to:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data homes_fixed;&lt;BR /&gt;length new_fname $8.; &lt;BR /&gt;set Homes;&lt;/P&gt;
&lt;P&gt;do i=1 by 1 while (scan(fname,i,'&amp;amp;+') ^=''); &lt;BR /&gt;new_fname=trim(scan(fname,i,'&amp;amp;+')); &lt;BR /&gt;output; &lt;BR /&gt;end; &lt;BR /&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;but '&lt;SPAN&gt;Raggedy Anne and Andy' and 'Ernie but not Bert' doesn't split (don't see how to put&amp;nbsp;text ' and ' into scan function...)&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;I'm ok with a prxchange/ prxmatch solution as well but trim(scan is a little easier to understand....&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;Thanks for any help!&lt;/SPAN&gt;&lt;/P&gt;</description>
    <pubDate>Wed, 01 Aug 2018 20:01:59 GMT</pubDate>
    <dc:creator>cjinsf</dc:creator>
    <dc:date>2018-08-01T20:01:59Z</dc:date>
    <item>
      <title>Splitting rows into multiple columns based on a mix of chars and strings ('and', '+', '&amp;', etc)</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483180#M125276</link>
      <description>&lt;P&gt;Hi!&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Trying to figure out how to split rows into multiple rows based on words or characters in a variable.&amp;nbsp; Searched but didn't find anything that mixed text and chars as a solution....&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;fname in data below contains 'and', '+', '&amp;amp;' , 'and not' as the words to split the rows.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data homes;&lt;BR /&gt;length fname $100 lname $19 addr $38 city $20 state $2 zip 8;&lt;BR /&gt;infile cards dlm="|" ;&lt;BR /&gt;input fname $ lname $ addr $ city $ state $ zip;&lt;BR /&gt;cards;&lt;BR /&gt;Raggedy Anne and Andy|Family|In The Attic|DC|DC|20007&lt;BR /&gt;Batman + Robin|Superduders|The Batcave|Gotham|NY|10012&lt;BR /&gt;Jack &amp;amp; Jill|Smith|123 Uphill Rd|Alma|CO|80420&lt;/P&gt;
&lt;P&gt;Ernie but not Bert|Muppet|Sesame Street|NY|NY|10128&lt;/P&gt;
&lt;P&gt;;&lt;BR /&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;want:&lt;/P&gt;
&lt;TABLE width="1014"&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="169"&gt;fname&lt;/TD&gt;
&lt;TD width="169"&gt;lname&lt;/TD&gt;
&lt;TD width="169"&gt;addr&lt;/TD&gt;
&lt;TD width="169"&gt;city&lt;/TD&gt;
&lt;TD width="169"&gt;state&lt;/TD&gt;
&lt;TD width="169"&gt;zip&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Raggedy Anne&lt;/TD&gt;
&lt;TD&gt;Family&lt;/TD&gt;
&lt;TD&gt;In The Attic&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;20007&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Andy&lt;/TD&gt;
&lt;TD&gt;Family&lt;/TD&gt;
&lt;TD&gt;In The Attic&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;DC&lt;/TD&gt;
&lt;TD&gt;20007&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Batman&lt;/TD&gt;
&lt;TD&gt;Superduders&lt;/TD&gt;
&lt;TD&gt;The Batcave&lt;/TD&gt;
&lt;TD&gt;Gotham&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10012&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Robin&lt;/TD&gt;
&lt;TD&gt;Superduders&lt;/TD&gt;
&lt;TD&gt;The Batcave&lt;/TD&gt;
&lt;TD&gt;Gotham&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10012&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Jack&lt;/TD&gt;
&lt;TD&gt;Smith&lt;/TD&gt;
&lt;TD&gt;123 Uphill Rd&lt;/TD&gt;
&lt;TD&gt;Alma&lt;/TD&gt;
&lt;TD&gt;CO&lt;/TD&gt;
&lt;TD&gt;80420&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Jill&lt;/TD&gt;
&lt;TD&gt;Smith&lt;/TD&gt;
&lt;TD&gt;123 Uphill Rd&lt;/TD&gt;
&lt;TD&gt;Alma&lt;/TD&gt;
&lt;TD&gt;CO&lt;/TD&gt;
&lt;TD&gt;80420&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Ernie&lt;/TD&gt;
&lt;TD&gt;Muppet&lt;/TD&gt;
&lt;TD&gt;Sesame Street&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10128&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;Bert&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;Muppet&lt;/TD&gt;
&lt;TD&gt;Sesame Street&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;NY&lt;/TD&gt;
&lt;TD&gt;10128&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&lt;BR /&gt;I've gotten to:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;data homes_fixed;&lt;BR /&gt;length new_fname $8.; &lt;BR /&gt;set Homes;&lt;/P&gt;
&lt;P&gt;do i=1 by 1 while (scan(fname,i,'&amp;amp;+') ^=''); &lt;BR /&gt;new_fname=trim(scan(fname,i,'&amp;amp;+')); &lt;BR /&gt;output; &lt;BR /&gt;end; &lt;BR /&gt;run;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;but '&lt;SPAN&gt;Raggedy Anne and Andy' and 'Ernie but not Bert' doesn't split (don't see how to put&amp;nbsp;text ' and ' into scan function...)&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;I'm ok with a prxchange/ prxmatch solution as well but trim(scan is a little easier to understand....&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;Thanks for any help!&lt;/SPAN&gt;&lt;/P&gt;</description>
      <pubDate>Wed, 01 Aug 2018 20:01:59 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483180#M125276</guid>
      <dc:creator>cjinsf</dc:creator>
      <dc:date>2018-08-01T20:01:59Z</dc:date>
    </item>
    <item>
      <title>Re: Splitting rows into multiple columns based on a mix of chars and strings ('and', '+', '&amp;', e</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483212#M125293</link>
      <description>&lt;P&gt;One approach might be to replace a string in the phrase with a single character so the scan works.&lt;/P&gt;
&lt;P&gt;Consider&lt;/P&gt;
&lt;PRE&gt;data homes;
   length fname $100 lname $19 addr $38 city $20 state $2 zip 8;
   infile cards dlm="|" ;
   input fname $ lname $ addr $ city $ state $ zip;
cards;
Raggedy Anne and Andy|Family|In The Attic|DC|DC|20007
Batman + Robin|Superduders|The Batcave|Gotham|NY|10012
Jack &amp;amp; Jill|Smith|123 Uphill Rd|Alma|CO|80420
Ernie but not Bert|Muppet|Sesame Street|NY|NY|10128
Fred and not Dorf|Muppet|Sesame Street|NY|NY|10128
;
run;

data homes_fixed;
   length new_fname $8.; 
   set Homes;
   tempfname = fname;
   tempfname = tranwrd(tempfname,' and not ','+');
   tempfname = tranwrd(tempfname,' but not ','+');
   tempfname = tranwrd(tempfname,' and ','+');
   do i=1 by 1 while (scan(tempfname,i,'&amp;amp;+') ^=''); 
      new_fname=strip(scan(tempfname,i,'&amp;amp;+')); 
      output; 
   end; 
run;

&lt;/PRE&gt;
&lt;P&gt;Notice that the tranwrd is looking for " and ", spaces as part of the search on both ends. That prevents removing "and" when it is part of a name or other word such as Bertrand.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;And that the longer phrases " and not " are searched for before " and ". That means the longer phrase is removed first.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I include " but not " as that was in the data but your requirement was "data below contains 'and', '+', '&amp;amp;' , 'and not' as the word"&lt;/P&gt;</description>
      <pubDate>Wed, 01 Aug 2018 21:58:18 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483212#M125293</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2018-08-01T21:58:18Z</dc:date>
    </item>
    <item>
      <title>Re: Splitting rows into multiple columns based on a mix of chars and strings ('and', '+', '&amp;', e</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483602#M125420</link>
      <description>&lt;P&gt;That works- thanks!&lt;/P&gt;</description>
      <pubDate>Thu, 02 Aug 2018 21:53:48 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Splitting-rows-into-multiple-columns-based-on-a-mix-of-chars-and/m-p/483602#M125420</guid>
      <dc:creator>cjinsf</dc:creator>
      <dc:date>2018-08-02T21:53:48Z</dc:date>
    </item>
  </channel>
</rss>

