<?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: Splitting a list from a row of a table in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Splitting-a-list-from-a-row-of-a-table/m-p/386449#M277223</link>
    <description>&lt;P&gt;No macros needed.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Use COUNTW to determine the number of words.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Use SCAN() to separate into components.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Your logic is close: &amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;n_words = countw(....);

Do I=1 to n_words;

    Word = scan(....);

    OUTPUT;

end;&lt;/CODE&gt;&lt;/PRE&gt;</description>
    <pubDate>Tue, 08 Aug 2017 23:26:19 GMT</pubDate>
    <dc:creator>Reeza</dc:creator>
    <dc:date>2017-08-08T23:26:19Z</dc:date>
    <item>
      <title>Splitting a list from a row of a table</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Splitting-a-list-from-a-row-of-a-table/m-p/386444#M277222</link>
      <description>&lt;P&gt;How do I split a specific list&amp;nbsp;in a column into individual items?&lt;/P&gt;&lt;P&gt;Let's say I have the columns Time and Greetings, and I want to split whatever is in Greetings for Time = PM.&lt;/P&gt;&lt;P&gt;Assume you don't know how many items will be on the list - greetings for PM could be 1, 2, 3, 4, 5+ etc. items long&lt;/P&gt;&lt;P&gt;Whatever is in Greetings is being referenced by another variable i.e. For PM, list in Greetings is from &amp;amp;PM_items.&lt;/P&gt;&lt;P&gt;where &amp;amp;PM_items. contains "&lt;SPAN&gt;Bye", "Adios", "Goodbye", "See you" - though these items can change.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;Before:&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp;&amp;nbsp;&lt;U&gt;Time&lt;/U&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; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&lt;U&gt;Greetings&lt;/U&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;AM &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; "Hello", "Hi", "Good morning"&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;PM &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; "Bye", "Adios", "Goodbye", "See you"&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;Any &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; "How are you"&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;After:&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &lt;U&gt;Time&lt;/U&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; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;&lt;U&gt;Greetings&lt;/U&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; AM &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp;"Hello", "Hi", "Good morning"&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;PM1 &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;"Bye"&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;PM2 &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; "Adios"&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;PM3 &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; "Goodbye"&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp;PM4 &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;"See you"&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; Any &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; "How are you"&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;/* Maybe something like my attempt at the code? */

Data want;
      Set have;
      If PM ^= ""&lt;BR /&gt;      For i.&amp;amp;PM_items. to last.&amp;amp;PM_items.
          do; &lt;BR /&gt;             &amp;amp;PM_items&amp;amp;i.&lt;BR /&gt;             next i;&lt;BR /&gt;          end;&lt;BR /&gt;      Then output;&lt;BR /&gt;Run;&lt;/PRE&gt;</description>
      <pubDate>Tue, 08 Aug 2017 22:55:11 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Splitting-a-list-from-a-row-of-a-table/m-p/386444#M277222</guid>
      <dc:creator>jos283</dc:creator>
      <dc:date>2017-08-08T22:55:11Z</dc:date>
    </item>
    <item>
      <title>Re: Splitting a list from a row of a table</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Splitting-a-list-from-a-row-of-a-table/m-p/386449#M277223</link>
      <description>&lt;P&gt;No macros needed.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Use COUNTW to determine the number of words.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Use SCAN() to separate into components.&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Your logic is close: &amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;n_words = countw(....);

Do I=1 to n_words;

    Word = scan(....);

    OUTPUT;

end;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Tue, 08 Aug 2017 23:26:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Splitting-a-list-from-a-row-of-a-table/m-p/386449#M277223</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2017-08-08T23:26:19Z</dc:date>
    </item>
  </channel>
</rss>

