<?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: Get last day the week in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508887#M136712</link>
    <description>&lt;P&gt;1. Add W to get in a week format that SAS understands, ie 2018W01, 2018W02, 2018W03&lt;/P&gt;
&lt;P&gt;2. Convert to a SAS date using INPUT and the WEEKV informat&lt;/P&gt;
&lt;P&gt;3. Increment to the end of the week.&lt;/P&gt;
&lt;P&gt;For the WEEKV rules:&lt;/P&gt;
&lt;P&gt;&lt;A href="https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=leforinforref&amp;amp;docsetTarget=n0d1k4sxmnxvvrn1732gg8u0t3th.htm&amp;amp;locale=en" target="_blank"&gt;https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=leforinforref&amp;amp;docsetTarget=n0d1k4sxmnxvvrn1732gg8u0t3th.htm&amp;amp;locale=en&lt;/A&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;*create sample data to test - please provide this in the future;
data have;
input date $ value $;
cards;
201801 a
201802 b
201803 c
;
run;


data want;
set have;

	/*1 Add W*/
	dateW = catt(substr(date, 1, 4), 'W', substr(date, 5, 2));

	/*2 Convert to SAS Date*/
	z = input(dateW, weekv.);

	/*3. Find end of week*/
	x = intnx('week', z, 0, 'e');

	/*4 doing it in one step*/
	x2 = intnx('week', input(catt(substr(date, 1, 4), 'W', substr(date, 5, 2)), weekv.), 0, 'e');

	*Format appearance;
	format x x2 date9.;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/209153"&gt;@kz134&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;Hi&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I have a dataset that is split by weeks. example:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;Date&lt;/TD&gt;
&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201801&lt;/TD&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201802&lt;/TD&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201803&lt;/TD&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The date indicates the week number of the year. The date is in character format. How do convert the date to get the last day of that week instead?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Want:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;Date&lt;/TD&gt;
&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;Date2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201801&lt;/TD&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;TD&gt;2018-01-06&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201802&lt;/TD&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;TD&gt;2018-01-13&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201803&lt;/TD&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;TD&gt;2018-01-20&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Tue, 30 Oct 2018 18:58:31 GMT</pubDate>
    <dc:creator>Reeza</dc:creator>
    <dc:date>2018-10-30T18:58:31Z</dc:date>
    <item>
      <title>Get last day the week</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508875#M136709</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have a dataset that is split by weeks. example:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Date&lt;/TD&gt;&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201801&lt;/TD&gt;&lt;TD&gt;a&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201802&lt;/TD&gt;&lt;TD&gt;b&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201803&lt;/TD&gt;&lt;TD&gt;c&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The date indicates the week number of the year. The date is in character format. How do convert the date to get the last day of that week instead?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Want:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Date&lt;/TD&gt;&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;&lt;TD&gt;Date2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201801&lt;/TD&gt;&lt;TD&gt;a&lt;/TD&gt;&lt;TD&gt;2018-01-06&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201802&lt;/TD&gt;&lt;TD&gt;b&lt;/TD&gt;&lt;TD&gt;2018-01-13&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;201803&lt;/TD&gt;&lt;TD&gt;c&lt;/TD&gt;&lt;TD&gt;2018-01-20&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Tue, 30 Oct 2018 18:45:55 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508875#M136709</guid>
      <dc:creator>kz134</dc:creator>
      <dc:date>2018-10-30T18:45:55Z</dc:date>
    </item>
    <item>
      <title>Re: Get last day the week</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508887#M136712</link>
      <description>&lt;P&gt;1. Add W to get in a week format that SAS understands, ie 2018W01, 2018W02, 2018W03&lt;/P&gt;
&lt;P&gt;2. Convert to a SAS date using INPUT and the WEEKV informat&lt;/P&gt;
&lt;P&gt;3. Increment to the end of the week.&lt;/P&gt;
&lt;P&gt;For the WEEKV rules:&lt;/P&gt;
&lt;P&gt;&lt;A href="https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=leforinforref&amp;amp;docsetTarget=n0d1k4sxmnxvvrn1732gg8u0t3th.htm&amp;amp;locale=en" target="_blank"&gt;https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=leforinforref&amp;amp;docsetTarget=n0d1k4sxmnxvvrn1732gg8u0t3th.htm&amp;amp;locale=en&lt;/A&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;*create sample data to test - please provide this in the future;
data have;
input date $ value $;
cards;
201801 a
201802 b
201803 c
;
run;


data want;
set have;

	/*1 Add W*/
	dateW = catt(substr(date, 1, 4), 'W', substr(date, 5, 2));

	/*2 Convert to SAS Date*/
	z = input(dateW, weekv.);

	/*3. Find end of week*/
	x = intnx('week', z, 0, 'e');

	/*4 doing it in one step*/
	x2 = intnx('week', input(catt(substr(date, 1, 4), 'W', substr(date, 5, 2)), weekv.), 0, 'e');

	*Format appearance;
	format x x2 date9.;
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/209153"&gt;@kz134&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;Hi&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I have a dataset that is split by weeks. example:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;Date&lt;/TD&gt;
&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201801&lt;/TD&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201802&lt;/TD&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201803&lt;/TD&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;The date indicates the week number of the year. The date is in character format. How do convert the date to get the last day of that week instead?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Want:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;TABLE&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD&gt;Date&lt;/TD&gt;
&lt;TD&gt;value&amp;nbsp;&lt;/TD&gt;
&lt;TD&gt;Date2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201801&lt;/TD&gt;
&lt;TD&gt;a&lt;/TD&gt;
&lt;TD&gt;2018-01-06&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201802&lt;/TD&gt;
&lt;TD&gt;b&lt;/TD&gt;
&lt;TD&gt;2018-01-13&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD&gt;201803&lt;/TD&gt;
&lt;TD&gt;c&lt;/TD&gt;
&lt;TD&gt;2018-01-20&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 30 Oct 2018 18:58:31 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508887#M136712</guid>
      <dc:creator>Reeza</dc:creator>
      <dc:date>2018-10-30T18:58:31Z</dc:date>
    </item>
    <item>
      <title>Re: Get last day the week</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508888#M136713</link>
      <description>&lt;P&gt;How do you define "last day of the week" ?&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Why should the first week end on January 6, not January 7?&lt;/P&gt;</description>
      <pubDate>Tue, 30 Oct 2018 18:58:31 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508888#M136713</guid>
      <dc:creator>Astounding</dc:creator>
      <dc:date>2018-10-30T18:58:31Z</dc:date>
    </item>
    <item>
      <title>Re: Get last day the week</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508898#M136717</link>
      <description>&lt;P&gt;worked well. thank you&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Tue, 30 Oct 2018 19:28:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Get-last-day-the-week/m-p/508898#M136717</guid>
      <dc:creator>kz134</dc:creator>
      <dc:date>2018-10-30T19:28:24Z</dc:date>
    </item>
  </channel>
</rss>

