<?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: Extract part of a string having positional delimiter in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444138#M282917</link>
    <description>&lt;P&gt;Hi Ksharp,&amp;nbsp;&lt;/P&gt;&lt;P&gt;can you kindly help me to extend this code to count the position of PIPE from ABC. As ABC segment may be preceded by other string. My target is to extract content available between 3rd and 4th pipe from the term ABC.&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data HAVE;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 X01|X02|ABC|X01|X02|2001|DEF
102 X01|X02|X02|ABC|X001|X002|2002|DEF
103 X01|X02|ABC|X0001|X0002|2003|DEF
104 X01|X02|X02|ABC|X00001|X00002|2004|DEF
105 X01|X02|ABC|X01|X02|2005|DEF
;
RUN;


data WANT;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 2001
102 2002
103 2003
104 2004
105 2005
;
RUN;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;Once again thanks for your kind response.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Fri, 09 Mar 2018 14:41:47 GMT</pubDate>
    <dc:creator>DeepakSwain</dc:creator>
    <dc:date>2018-03-09T14:41:47Z</dc:date>
    <item>
      <title>Extract part of a string having positional delimiter</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444082#M282914</link>
      <description>&lt;P&gt;Hi there,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am trying to extract part of a string available between 3rd and 4th pipe. Can anybody please assist me to move forward.&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data HAVE;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 ABC|X01|X02|2001|DEF
102 ABC|X001|X002|2002|DEF
103 ABC|X0001|X0002|2003|DEF
104 ABC|X00001|X00002|2004|DEF
105 ABC|X01|X02|2005|DEF
;
RUN;


data WANT;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 2001
102 2002
103 2003
104 2004
105 2005
;
RUN;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;Thank you in advance for your kind guidance.&amp;nbsp;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;</description>
      <pubDate>Fri, 09 Mar 2018 13:53:56 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444082#M282914</guid>
      <dc:creator>DeepakSwain</dc:creator>
      <dc:date>2018-03-09T13:53:56Z</dc:date>
    </item>
    <item>
      <title>Re: Extract part of a string having positional delimiter</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444096#M282915</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data HAVE;
length id $3 comment $50 ;
input id comment $ ;

want=scan(comment,-2,'|');

datalines;
101 ABC|X01|X02|2001|DEF
102 ABC|X001|X002|2002|DEF
103 ABC|X0001|X0002|2003|DEF
104 ABC|X00001|X00002|2004|DEF
105 ABC|X01|X02|2005|DEF
;
RUN;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Fri, 09 Mar 2018 14:15:02 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444096#M282915</guid>
      <dc:creator>Ksharp</dc:creator>
      <dc:date>2018-03-09T14:15:02Z</dc:date>
    </item>
    <item>
      <title>Re: Extract part of a string having positional delimiter</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444097#M282916</link>
      <description>&lt;P&gt;You could use the SCAN() function.&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;comment=scan(comment,4,'|');&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Fri, 09 Mar 2018 14:16:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444097#M282916</guid>
      <dc:creator>Tom</dc:creator>
      <dc:date>2018-03-09T14:16:19Z</dc:date>
    </item>
    <item>
      <title>Re: Extract part of a string having positional delimiter</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444138#M282917</link>
      <description>&lt;P&gt;Hi Ksharp,&amp;nbsp;&lt;/P&gt;&lt;P&gt;can you kindly help me to extend this code to count the position of PIPE from ABC. As ABC segment may be preceded by other string. My target is to extract content available between 3rd and 4th pipe from the term ABC.&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data HAVE;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 X01|X02|ABC|X01|X02|2001|DEF
102 X01|X02|X02|ABC|X001|X002|2002|DEF
103 X01|X02|ABC|X0001|X0002|2003|DEF
104 X01|X02|X02|ABC|X00001|X00002|2004|DEF
105 X01|X02|ABC|X01|X02|2005|DEF
;
RUN;


data WANT;
length id $3 comment $50 ;
input id comment $ ;
datalines;
101 2001
102 2002
103 2003
104 2004
105 2005
;
RUN;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;Once again thanks for your kind response.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 09 Mar 2018 14:41:47 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Extract-part-of-a-string-having-positional-delimiter/m-p/444138#M282917</guid>
      <dc:creator>DeepakSwain</dc:creator>
      <dc:date>2018-03-09T14:41:47Z</dc:date>
    </item>
  </channel>
</rss>

