<?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 Convert string variable YYYYMMDDHHMM to datetime format in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Convert-string-variable-YYYYMMDDHHMM-to-datetime-format/m-p/811838#M320254</link>
    <description>&lt;P&gt;I have been trying to convert a string variable that consists of date and time to a SAS datetime format.&amp;nbsp;&lt;/P&gt;&lt;P&gt;Can you recommend a method?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;DATA&lt;/STRONG&gt; test;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; input date $16.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; datalines;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203020719&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203030922&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203070757&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;RUN&lt;/STRONG&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;DATA&lt;/STRONG&gt; test2;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SET test;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; new_date = put(input(substr(date, &lt;STRONG&gt;1&lt;/STRONG&gt;, &lt;STRONG&gt;8&lt;/STRONG&gt;), yymmdd8.), date9.);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; new_time = substr(date, &lt;STRONG&gt;9&lt;/STRONG&gt;, &lt;STRONG&gt;4&lt;/STRONG&gt;);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; time_numeric = input(substr(new_time,&lt;STRONG&gt;1&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;) !! ':' !! substr(new_time,&lt;STRONG&gt;3&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),time5.);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; hr = input(substr(new_time,&lt;STRONG&gt;1&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),&lt;STRONG&gt;2.&lt;/STRONG&gt;) ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; min = input(substr(new_time,&lt;STRONG&gt;3&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),&lt;STRONG&gt;2.&lt;/STRONG&gt;) ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sec = &lt;STRONG&gt;00&lt;/STRONG&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; *sasdt = dhms(new_date, hr, min, sec); /*This line of code does not work*/&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;run&lt;/STRONG&gt;;&lt;/P&gt;</description>
    <pubDate>Fri, 06 May 2022 11:03:38 GMT</pubDate>
    <dc:creator>amateur_expert</dc:creator>
    <dc:date>2022-05-06T11:03:38Z</dc:date>
    <item>
      <title>Convert string variable YYYYMMDDHHMM to datetime format</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-string-variable-YYYYMMDDHHMM-to-datetime-format/m-p/811838#M320254</link>
      <description>&lt;P&gt;I have been trying to convert a string variable that consists of date and time to a SAS datetime format.&amp;nbsp;&lt;/P&gt;&lt;P&gt;Can you recommend a method?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;DATA&lt;/STRONG&gt; test;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; input date $16.;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; datalines;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203020719&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203030922&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 202203070757&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;RUN&lt;/STRONG&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;DATA&lt;/STRONG&gt; test2;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SET test;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; new_date = put(input(substr(date, &lt;STRONG&gt;1&lt;/STRONG&gt;, &lt;STRONG&gt;8&lt;/STRONG&gt;), yymmdd8.), date9.);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; new_time = substr(date, &lt;STRONG&gt;9&lt;/STRONG&gt;, &lt;STRONG&gt;4&lt;/STRONG&gt;);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; time_numeric = input(substr(new_time,&lt;STRONG&gt;1&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;) !! ':' !! substr(new_time,&lt;STRONG&gt;3&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),time5.);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; hr = input(substr(new_time,&lt;STRONG&gt;1&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),&lt;STRONG&gt;2.&lt;/STRONG&gt;) ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; min = input(substr(new_time,&lt;STRONG&gt;3&lt;/STRONG&gt;,&lt;STRONG&gt;2&lt;/STRONG&gt;),&lt;STRONG&gt;2.&lt;/STRONG&gt;) ;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; sec = &lt;STRONG&gt;00&lt;/STRONG&gt;;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; *sasdt = dhms(new_date, hr, min, sec); /*This line of code does not work*/&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;run&lt;/STRONG&gt;;&lt;/P&gt;</description>
      <pubDate>Fri, 06 May 2022 11:03:38 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-string-variable-YYYYMMDDHHMM-to-datetime-format/m-p/811838#M320254</guid>
      <dc:creator>amateur_expert</dc:creator>
      <dc:date>2022-05-06T11:03:38Z</dc:date>
    </item>
    <item>
      <title>Re: Convert string variable YYYYMMDDHHMM to datetime format</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Convert-string-variable-YYYYMMDDHHMM-to-datetime-format/m-p/811839#M320255</link>
      <description>&lt;P&gt;Use the proper informat and the INPUT function. There are several informats that might work including B8601DJ&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data want;
    set test;
    num_date_time=input(date,b8601dj12.);
    format num_date_time datetime16.;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Hint: Always use built in SAS functions (in this case INPUT with the proper informat) to work with dates and date/times. Don't try to create your own.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Hint 2: Date/time values should not have a variable name of DATE which indicates it is a date value and not a date time value.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 06 May 2022 11:17:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Convert-string-variable-YYYYMMDDHHMM-to-datetime-format/m-p/811839#M320255</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2022-05-06T11:17:04Z</dc:date>
    </item>
  </channel>
</rss>

