我正在尝试获取格式化的日期,包括毫秒数。
唯一的问题是我不断赚到000000
date("m-d-Y H:i:s.u", $milliseconds/1000);
例如 2013/07/28 11:26:14.000000
我正在尝试获取格式化的日期,包括毫秒数。
唯一的问题是我不断赚到000000
date("m-d-Y H:i:s.u", $milliseconds/1000);
例如 2013/07/28 11:26:14.000000
Answers:
php.net说:
微秒(在PHP 5.2.2中添加)。请注意,由于它采用整数参数,因此
date()
将始终生成000000
,而DateTime::format()
如果DateTime
使用微秒创建,则支持微秒。
所以使用就这么简单:
$micro_date = microtime();
$date_array = explode(" ",$micro_date);
$date = date("Y-m-d H:i:s",$date_array[1]);
echo "Date: $date:" . $date_array[0]."<br>";
推荐和使用dateTime()
参考类:
$t = microtime(true);
$micro = sprintf("%06d",($t - floor($t)) * 1000000);
$d = new DateTime( date('Y-m-d H:i:s.'.$micro, $t) );
print $d->format("Y-m-d H:i:s.u"); // note at point on "u"
注意u
是微秒(1秒= 1000000 µs)。
来自php.net的另一个示例:
$d2=new DateTime("2012-07-08 11:14:15.889342");
参考dateTime()
上php.net
我已经回答了简短的问题,并简化为作者。请参阅作者的更多信息:从毫秒获取日期格式mdY H:i:su
microtime(false)
两者都不起作用。)
您可以使用输入格式轻松地做到这一点U.u
。
$now = DateTime::createFromFormat('U.u', microtime(true));
echo $now->format("m-d-Y H:i:s.u");
这将产生以下输出:
04-13-2015 05:56:22.082300
从PHP手册页获取日期格式:
http://php.net/manual/zh/function.date.php
感谢gggsey指出了我原来的答案中的一个缺陷,将其添加number_format()
到行中应该可以确定确切的秒数。太糟糕了,感觉不再优雅了...
$now = DateTime::createFromFormat('U.u', number_format(microtime(true), 6, '.', ''));
http://php.net/manual/zh/function.number-format.php
关于DaVe的时区说明。
通常,createFromFormat()
如果未指定本地时区,则该方法将使用本地时区。
http://php.net/manual/en/datetime.createfromformat.php
但是,此处描述的技术是初始化DateTime对象microtime()
,该对象用于返回自Unix纪元(1970年1月1日00:00:00 GMT)以来经过的秒数。
http://php.net/manual/zh/function.microtime.php
这意味着DateTime对象被隐式初始化为UTC,这对于只想跟踪经过时间的服务器内部任务很好。
如果需要显示特定时区的时间,则需要进行相应设置。但是,由于上述原因,应在初始化后(不使用的第三个参数createFromFormat()
)作为一个单独的步骤进行操作。
该setTimeZone()
方法可用于完成此要求。
http://php.net/manual/en/datetime.settimezone.php
举个例子:
$now = DateTime::createFromFormat('U.u', number_format(microtime(true), 6, '.', ''));
echo $now->format("m-d-Y H:i:s.u") . '<br>';
$local = $now->setTimeZone(new DateTimeZone('Australia/Canberra'));
echo $local->format("m-d-Y H:i:s.u") . '<br>';
产生以下输出:
10-29-2015 00:40:09.433818
10-29-2015 11:40:09.433818
请注意,如果要输入mysql,则时间格式必须为:
format("Y-m-d H:i:s.u")
DateTime::createFromFormat('U.u', microtime(true));
如果microtime(true)
精确到秒,将返回false 。它返回“ 1438616239”而不是“ 1438616239.000000”。
number_format
始终是必要的,即使它不是确切的第二位。否则,您会受到precision
PHP配置选项(“显示”)的支配,该选项在PHP 7.0之前默认情况下不够高,从而导致精度损失(精确到微秒)。
echo date('m-d-Y H:i:s').substr(fmod(microtime(true), 1), 1);
示例输出:
02-06-2019 16:45:03.53811192512512
如果您需要限制小数位数,那么下面的行(credit mgutt)将是一个很好的选择。(对于下面的代码,6会将小数位数限制为6。)
echo date('m-d-Y H:i:').sprintf('%09.6f', date('s')+fmod(microtime(true), 1));
示例输出:
02-11-2019 15:33:03.624493
echo date('m-d-Y H:i:').sprintf('%09.6f', date('s')+fmod(microtime(true), 1));
。说明我们为什么需要09
:stackoverflow.com/a/28739819/318765
echo date('H:i:s').substr(fmod(microtime(true), 1), 1, 7);
substr()
不会四舍五入。与此相伴的是,round()
它会减少尾随的零:stackoverflow.com/questions/7493305 / ...这就是我提出的原因sprintf()
。
如果您(new Date()).toISOString()
出于某种原因想要格式化像JavaScript这样的日期,可以通过以下方式在PHP中进行操作:
$now = microtime(true);
gmdate('Y-m-d\TH:i:s', $now).sprintf('.%03dZ',round(($now-floor($now))*1000));
样本输出:
2016-04-27T18:25:56.696Z
只是为了证明减去整数不会降低小数部分的精度:
>>> number_format(123.01234567890123456789,25)
=> "123.0123456789012408307826263"
>>> number_format(123.01234567890123456789-123,25)
=> "0.0123456789012408307826263"
PHP 确实舍入了小数位,但在两种情况下都以相同的方式将它们舍入。
date('Y-m-d\TH:i:s', $time / 1000) . sprintf('.%03dZ', substr($time, 10));
呢
$time
已经以毫秒为单位,是的,这在技术上是可行的。不喜欢这种substr
骇客,但我猜想它适用于2001年到2286
$time
是MS,但是,那是什么2286
意思,为什么要这样想以及如何有可能摆脱这种情况?
这基于ArchCodeMonkey的答案。
但是只是简化了一下,如果您只想快速实用的话。
function DateTime_us_utc(){
return DateTime::createFromFormat('U.u', number_format(microtime(true), 6, '.', ''));
}
function DateTime_us(){
$now = DateTime_us_utc();
return $now->setTimeZone(new DateTimeZone(date_default_timezone_get()));
}
所以对我来说
$now = DateTime_us();
$now->format("m-d-Y H:i:s.u");
该文档说:
微秒(在PHP 5.2.2中添加)。请注意,由于date()使用整数参数,因此它将始终生成000000,而DateTime :: format()确实支持微秒。
即,改用DateTime。
new DateTime()
也将返回0000。但是,如果在实例化时为其提供了微秒精度的时间,则可以正常工作。
new DateTime( 'Y-m-d H:i:s.'.$micro);
现在使用PHP 7.0+,您可以执行以下操作:
$dateString = substr($millseconds_go_here,0,10);
$drawDate = new \DateTime(Date('Y-m-d H:i',$dateString));
$drawDate->setTimezone(new \DateTimeZone('UTC'));
这将按顺序执行以下操作:
Date()
可以处理日期。DateTime()
可以让您修改您所在的时区,但是date_default_timezone_set("Timezone");
在使用DateTime()
函数和类之前请确保已设置该时区。DateTime()
使用类或函数时使用正确的时区。我采用了几种不同的方法:
1)microtime + sscanf +日期:
sscanf(microtime(), '0.%6s00 %s', $usec, $sec);
$date = date('Y-m-d H:i:s.', $sec) . $usec;
我不确定为什么microtime()在微秒部分返回10个字符(0.dddddd00),但是也许有人可以告诉我?
$start_ts = microtime(true); for($i = 0; $i < 10000000; $i++) { sscanf(microtime(), '0.%6s00 %s', $usec, $sec); $date = date('Y-m-d H:i:s.', $sec) . $usec; } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "22372.335910797 ms" // macOS PHP 5.6.30
string(18) "16772.964000702 ms" // Linux PHP 5.4.16
string(18) "10382.229089737 ms" // Linux PHP 7.3.11 (same linux box as above)
2)DateTime :: createFromFormat + Datetime-> format:
$now = new DateTime('NOW');
$date = $now->format('Y-m-d H:i:s.u');
在PHP 5.x中不起作用...
$start_ts = microtime(true); for($i = 0; $i < 10000000; $i++) { $now = new DateTime('NOW'); $date = $now->format('Y-m-d H:i:s.u'); } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "45801.825046539 ms" // macOS PHP 5.6.30 (ms not working)
string(18) "21180.155038834 ms" // Linux PHP 5.4.16 (ms not working)
string(18) "11879.796028137 ms" // Linux PHP 7.3.11 (same linux box as above)
3)gettimeofday +日期:
$time = gettimeofday();
$date = date('Y-m-d H:i:s.', $time['sec']) . $time['usec'];
--
$start_ts = microtime(true); for($i = 0; $i < 10000000; $i++) { $time = gettimeofday(); $date = date('Y-m-d H:i:s.', $time['sec']) . $time['usec']; } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "23706.788063049 ms" // macOS PHP 5.6.30
string(18) "14984.534025192 ms" // Linux PHP 5.4.16
string(18) "7799.1390228271 ms" // Linux PHP 7.3.11 (same linux box as above)
4)microtime + number_format + DateTime :: createFromFormat + DateTime-> format:
$now = DateTime::createFromFormat('U.u', number_format(microtime(true), 6, '.', ''));
$date = $now->format('Y-m-d H:i:s.u');
--
$start_ts = microtime(true); for($i = 0; $i < 10000000; $i++) { $now = DateTime::createFromFormat('U.u', number_format(microtime(true), 6, '.', '')); $date = $now->format('Y-m-d H:i:s.u'); } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "83326.496124268 ms" // macOS PHP 5.6.30
string(18) "61982.603788376 ms" // Linux PHP 5.4.16
string(16) "19107.1870327 ms" // Linux PHP 7.3.11 (same linux box as above)
5)microtime + sprintf + DateTime :: createFromFormat + DateTime-> format:
$now = DateTime::createFromFormat('U.u', sprintf('%.6f', microtime(true)));
$date = $now->format('Y-m-d H:i:s.u');
--
$start_ts = microtime(true); for($i = 0; $i < 10000000; $i++) { $now = DateTime::createFromFormat('U.u', sprintf('%.6f', microtime(true))); $date = $now->format('Y-m-d H:i:s.u'); } var_dump((microtime(true) - $start_ts)*1000 . ' ms');
string(18) "79387.331962585 ms" // macOS PHP 5.6.30
string(18) "60734.437942505 ms" // Linux PHP 5.4.16
string(18) "18594.941139221 ms" // Linux PHP 7.3.11 (same linux box as above)