For EST time, I’ve set:
date_default_timezone_set("America/New_York");
As the page loads, I’m getting EST time via:
$time = time();
The problem is when I convert strings back and forth between timestamps and datetime format:
10/31/2012 7:30pm 1351729800 | 10/31/2012, 8:30 pm
11/2/2012 7:30pm 1351902600 | 11/02/2012, 8:30 pm
11/3/2012 8:00pm 1351990800 | 11/03/2012, 9:00 pm
11/7/2012 8:00pm 1352336400 | 11/07/2012, 8:00 pm
11/9/2012 8:00pm 1352509200 | 11/09/2012, 8:00 pm
11/10/2012 8:00pm 1352595600 | 11/10/2012, 8:00 pm
I’m expecting these date & times to be the same.
The first section (before the “|”) is simply strings, such as “10/31/2012 7:30pm” and the strtotime(“10/31/2012 7:30pm EST”).
The section (after the “|”) is date() of the previous strtotime() value.
What can I do to convert from string to time (strtotime) and double check that the date format returned is the same as the string input?
Thanks
I’d say that this is because currently New York is on daylight savings time – EDT rather than EST. This affects things like so:
The quick fix is probably to not add the timezone to the string,
strtotime()will use the correct default timezone you set.You can be a bit more exact about how your date is being parsed by using the
DateTimecreateFromFormatfunction:Alternatively if you wait until November the problem will resolve itself 🙂