|
gmdate
Format a GMT/UTC date/time
(PHP 4, PHP 5)
Example 451. gmdate() exampleWhen run in Finland (GMT +0200), the first line below prints "Jan 01 1998 00:00:00", while the second prints "Dec 31 1997 22:00:00". <?php Code Examples / Notes » gmdatekogik inc dot -- info
Wath out for summer time and winter time... If you want to get the current date and time based on GMT you could use this : $timezone = -5; //(GMT -5:00) EST (U.S. & Canada) echo gmdate("Y/m/j H:i:s", time() + 3600*($timezone+date("I"))); this would gives: 2004/07/8 14:35:19 in summer time and 2004/07/8 13:35:19 in winter time. Note that date("I") returns 1 in summer and 0 in winter. ncofrenospamplease
Want to put different International Times in your web? First create a database including the GMT and the DST (find it f.i. at timeanddate.com). Be careful, because there are several different DST dates and options. Once you have your function which calculates the GMT hour difference (it can be a decimal!!), sum it to the Unix Time (remember that unix time is GMT, not local: f.i. gmdate("U")===date("U)). Don't forget to recalculate the GMT difference to seconds before it. Then format your date using gmdate() (not date()!) and... you've got your International Time! <?php $city["Name"] = "Barcelona"; $city["GMT"] = 1.0; $city["actualDST"] = 1.0; //Because it's summer time $gmt_diff = $city["GMT"]+$city["actualDST"]; //your functions for getting the hour difference betweer the city and the GMT $city_time = time()+($gmt_diff*3600); //sum the timestamps echo gmdate("H:i"); //echo the formatted date echo " h. in the beautiful city of ".$city["Name"]; ?> chrisjj
This doc is faulty, saying: > Identical to the date() function except that the time > returned is Greenwich Mean Time (GMT). where the date() function says > T Timezone setting of this machine gmdate('T') does NOT return the Timezone setting of the machine. Instead it returns the machine's description of GMT, which may or may not be "GMT" tobias
Thanks to Kogik's contribution above I was able to find a way for exec a script thru cron a specific time (12:30, having the crontab on a US server and the actual script on a Swedish server. $timezone = 1; // (GMT 01:00) Amsterdam, Berlin, Bern, Rom, Stockholm, Wien $now = preg_replace('/\d{1}$/', 0, gmdate("H:i", time()+3600*($timezone+date("I")))); if ( $now == '12:30' ) echo 'ok to run..'; jhechtf
My function for something like this is like so: <?php function actual_time($format,$offset,$timestamp){ //Offset is in hours from gmt, including a - sign if applicable. //So lets turn offset into seconds $offset = $offset*60*60; $timestamp = $timestamp + $offset; //Remember, adding a negative is still subtraction ;) return gmdate($format,$timestamp); } ?> It's always worked fine for me. rob
It's worth noting the distinction between gmgate() and date() with regards to day light savings time. If your server uses universal time and makes an adjustment by locale for daylight savings time, you will want to use date(). gmdate will display the non-adjuisted time.
eddie dot_here bishop@gmail dot_here com
In response to ncofreNOSPAMPLEASE at step2u dot com, Your international time is all well and good, but you left out a VERY important piece of the code you provided. Change the second to last line from echo gmdate("H:i"); to echo gmdate("H:i", $city_time); Nice example, though, thanks! www.l-serwis.wpt.pl
If you want to get time in your timezone try this: $zone=3600*0 //GMT $zone=3600*1 //CET $zone=3600*-5//USA $date=gmdate("D M Y H:i", time() + $zone); fernandobassani
If you have the same application running in different countries, you may have some troubles getting the local time.. In my case, I was having troubles with a clock created with Macromedia Flash... the time shown by the clock was supposed to be set up by the server, passing the timestamp. When I moved the file to another country, I got a wrong time... You can use the timezone offset ( date("Z") ) to handle this kind of thing... <?php $timestamp = time()+date("Z"); echo gmdate("Y/m/d H:i:s",$timestamp); ?> gefiltefishee
I was struggling with how to get my browser to output MY local time using gmdate(). I figured it out and here's what you do (ASSUMING THE SERVER IS ON GMT, If not, just echo a generic gmdate() without timezone setting and calculate the number of hours ahead or behind you are of that time, convert it to seconds and add [for ahead] or subtract [for behind] that value to time() ): NOTE: these are US times [setlocale(LC_TIME, 'en_US')] for Central Time (7 hours behind GMT): gmdate("format", time()-(25200)); For Pacific Time (9 hours behind GMT): gmdate("format", time()-(32400)); REMEMBER - THE VALUES ABOVE ASSUME THE SERVER IS ON GMT I used the following gmdate() format: "l, F jS, Y g:i a" but you can use what you like ;) Hope this helps! code
I wanted to get the time past from two MySQL dates and came up with this code that does the trick. Supply a start date, end date and optional output date/time format the default is in seconds but will expand from SS to MM:SS and then to HH:MM:SS automatically, you may wish to force a date format that will not be dynamic (site layout etc). See examples below, also see function date() for more date format options. <? function calculate_time_past($start_time, $end_time, $format = "s") { $time_span = strtotime($end_time) - strtotime($start_time); if ($format == "s") { // is default format so dynamically calculate date format if ($time_span > 60) { $format = "i:s"; } if ($time_span > 3600) { $format = "H:i:s"; } } return gmdate($format, $time_span); } $start_time = "2007-03-28 00:50:14"; // 00:50:14 will work on its own $end_time = "2007-03-28 00:52:59"; // 00:52:59 will also work instead echo calculate_time_past($start_time, $end_time) . "<br />"; // will output 02:45 echo calculate_time_past($start_time, $end_time, "H:i:s"); // will output 00:02:45 when format is overridden ?> I hope it of use. Regards, Ashley derek
I don't really know what I'm doing, so I just stole various parts of this from other people around here and did a little improvising on my own. Hope this is helpful to somebody. This script allows you to insert just three variables: direction from GMT to your timezone ($sign), number of hours to your timezone ($h), and whether or not you have daylight savings time ($dst). The rest, including daylight savings time, will take care of itself (unless I don't know what I'm doing!). <?php // Get info about time zone relationship to GMT at: http://wwp.greenwichmeantime.com/ // SELECT TIME ZONE $sign = "-"; // Whichever direction from GMT to your timezone. $h = "8"; // Hour for time zone goes here e.g. +8 or -4, just remove the + or - $dst = "true"; // Just insert "true" if your location uses daylight savings time or "false" if it does not // DETECT AND ADJUST FOR DAYLIGHT SAVINGS TIME if ($dst) { $daylight_saving = date('I'); if ($daylight_saving){ if ($sign == "-"){ $h=$h-1; } else { $h=$h+1; } } } // FIND DIFFERENCE FROM GMT $hm = $h * 60; $ms = $hm * 60; // SET CURRENT TIME if ($sign == "-"){ $timestamp = time()-($ms); } else { $timestamp = time()+($ms); } // SAMPLE OUTPUT $gmdate = gmdate("m/d/Y g:i:s A", $timestamp); echo "Your current time now is : $gmdate . "; ?> faraz
Hi i was having a problem in converting a date to any time zone so I wrote my own function which coverts a given date and time to other time zone equivalent function printByTimeZone($mytime,$mydate,$mytimezone) { //assuming timezone in format +05:00 or -4:30 $conTime = $mytime; $conDate = $mydate; $tzonehr=substr($mytimezone,1,2); $tzonesec=substr($mytimezone,4,2); $sign= substr($mytimezone,0,1); $timezone=intval($tzonehr)*60 + ( intval($tzonesec)*3600); Switch($sign) { Case -: $timezone=$timezone*(-1); Break; } // write a method to extract your hours,min,sec,day,month,year (all should be in numeric form) $TimeStamp= mktime($yourhours, $yourmins,$yoursecs,$yourmonth,$yourday ,$youryear ,-1); $TimeStamp=$TimeStamp+$_GET['TimeZone']; $GMTDateTime=gmdate("H:i:s D M d Y",$TimeStamp); return $GMTDateTime; } blazeme
Here, I wrote a function (from code above) for easy time zone settings. Regards. <?php function datum($datum=true) { $sign = "+"; // Whichever direction from GMT to your timezone. + or - $h = "1"; // offset for time (hours) $dst = true; // true - use dst ; false - don't if ($dst==true) { $daylight_saving = date('I'); if ($daylight_saving){ if ($sign == "-"){ $h=$h-1; } else { $h=$h+1; } } } $hm = $h * 60; $ms = $hm * 60; if ($sign == "-"){ $timestamp = time()-($ms); } else { $timestamp = time()+($ms); } $gmdate = gmdate("m.d.Y. g:i A", $timestamp); if($datum==true) { return $gmdate; } else { return $timestamp; } } ?> If you set first argument to true, it'll return formated date. If false, will return $timestamp. Enjoy! sir derek g
Here's a nifty little function that returns a random timestamp between two dates. <? ////////////////////////////////////////////////////////// // Return a random timestamp between two dates (inclusive) // Example: Tue, 08 Nov 2004 06:47:10 GMT // // time - Starting time string // Valid Examples: // 10 September 2001 // next Thursday // last Monday // now // // time2 - Ending time string function randomTimestamp($time = "" , $time2 = "") { if(!$time) $time = strtotime("10 September 2000"); if(!$time2) $time2 = strtotime("24 November 2005"); $timestamp = date(" D, d M Y", rand( settype($time , int) , settype($time2 , int) )); //Must be called once before becoming random, ??? $timestamp = date(" D, d M Y", rand($time , $time2))." ";//Now it's random $h = rand(1,23); if(strlen($h) == 1 ) $h = "0$h"; $t = $h.":"; $d = rand(1,29); if(strlen($d) == 1 ) $d = "0$d"; $t .= $d.":"; $s = rand(0,59); if(strlen($s) == 1 ) $s = "0$s"; $t .= $s; $timestamp .= $t." GMT"; return $timestamp; } ?> paul
Gives user the ability to use their timezone preferences. I had to create this script for a very large community. I first made any posts to the database that would display the date using just time(); Example: mysql_query("INSERT INTO `table` (`datetime`) VALUES ('".time()."')"); Also, for their timezone preference, I had the values as (example): (Eastern Timezone) -5 hours (Newfoundland) -3 hours -30 minutes This information would be saved in the users table. To display the date and time in their respective timezone preference: function datetime($datetime,$zone){ if(date('I')):$datetime+=60*60;endif; return gmdate('m-d-Y - h:i:sa',strtotime($zone,$datetime)); } $datetime would be the information pulled from the database from a post for news, forums, etcetera (remember, the inserted table data for the time was using time();) $zone would be the information pulled from the database from the users timezone preference. I also used cookies to store their timezone: $sth=mysql_query("SELECT `datetime` FROM `table` LIMIT 1"); $row=mysql_fetch_assoc($sth); echo datetime($row['datetime'],$_COOKIE['timezone']); Remember to set the 'm-d-Y - h:i:sa' to how you wish the time to display. Visit the manual about date(). ttech5593
For me most of the examples here needed the + or - seconds to set the time zone. I wanted a faster way to get the time zone in seconds. So I created this : <?php $h = "3";// Hour for time zone goes here e.g. +7 or -4, just remove the + or - $hm = $h * 60; $ms = $hm * 60; $gmdate = gmdate("m/d/Y g:i:s A", time()-($ms)); // the "-" can be switched to a plus if that's what your time zone is. echo "Your current time now is : $gmdate . "; ?> It works. Hope it helps. 15-jun-2002 04:09
For an RFC 1123 (HTTP header date) date, try: $rfc_1123_date = gmdate('D, d M Y H:i:s T', time()); 08-sep-2002 05:26
Do not use the "T" timezone specifier to generate "GMT", as this may return "UTC" or "GMT+0000" or "Z" or something else which depends on the running platform, which would not be RFC1123 compliant. Use 'D, d M Y H:i:s \G\M\T' which forces the value of the timezone indicator. Note that RFC1123 requires the use of ENGLISH day and month abbreviations. They MUST NOT be localized! An example of the RFC1123 format for full dates is: Sun, 06 Nov 1994 08:49:37 GMT Note the presence of the leading 0 (RFC1123 dates have a fixed size, and space padding is prohibited because it causes problems with fixed size handling when such dates are used in HTTP headers that may compress whitespaces. Some proxies accept also the ISO 8601 format, but this is not documented in HTTP/1.1 specs (RFC2616). Examples: header('Date: '.gmdate('D, d M Y H:i:s \G\M\T', time())); header('Last-Modified: '.gmdate('D, d M Y H:i:s \G\M\T', time())); header('Expires: '.gmdate('D, d M Y H:i:s \G\M\T', time() + 3600)); or if you prefer double quotes and don't want to bother with double backslashes: header("Date: ".gmdate("D, d M Y H:i:s", time())." GMT"); header("Last-Modified: ".gmdate("D, d M Y H:i:s", time())." GMT");; header("Expires: ".gmdate("D, d M Y H:i:s", time() + 3600)." GMT"); webmaster
$zone=3600*2//SPAIN $date=gmdate("D M Y H:i", time() + $zone); |
Change Languagecheckdate date_create date_date_set date_default_timezone_get date_default_timezone_set date_format date_isodate_set date_modify date_offset_get date_parse date_sun_info date_sunrise date_sunset date_time_set date_timezone_get date_timezone_set date getdate gettimeofday gmdate gmmktime gmstrftime idate localtime microtime mktime strftime strptime strtotime time timezone_abbreviations_list timezone_identifiers_list timezone_name_from_abbr timezone_name_get timezone_offset_get timezone_open timezone_transitions_get |