PHP中的DateTime类

8-25 791 views

DataTime类跟date(),strtotime(),gmdate()等函数有相同的作用,都是用来处理日期和时间的,但DateTime类更加直观、方便, 所以在PHP5.2.0以后推荐使用DateTime类而不是相应的函数。

下面来看一下DateTime类的用法。

获取当前系统时间并打印
//1、获取当前系统时间并打印
$date = new DateTime();
echo $date->format('Y-m-d H:i:s');
echo "\n";

获取特定时间并打印
//2、获取特定时间并打印
$date = new DateTime('2014-05-04');
echo $date->format('Y-m-d H:i:s');
echo "\n";
$date2 = new DateTime('tomorrow');
echo $date2->format('Y-m-d H:i:s');
echo "\n";
$date2 = new DateTime('+2 days');
echo $date2->format('Y-m-d H:i:s');
echo '<hr/>';
$date = new DateTime();

// add方法
$date->add(new DateInterval('P1D'));
echo $date->format('Y-m-d H:i:s');
echo "\n";

// modify方法
$date->modify('+1 day');
echo $date->format('Y-m-d H:i:s');
echo "\n";

// setDate方法
$date->setDate('1989','11','10');
echo $date->format('Y-m-d H:i:s');
echo "\n";

// setTime方法
$date = new DateTime('2001-01-01');

$date->setTime(14, 55);
echo $date->format('Y-m-d H:i:s') . "\n";

$date->setTime(14, 55, 24);
echo $date->format('Y-m-d H:i:s') . "\n";

unix时间戳的转换
//3. unix时间戳的转换
//获取当前时间的时间戳
$date = new DateTime();
echo $date->format('U');
echo "\n";
//或者
$date = new DateTime();
echo $date->getTimestamp();
echo "\n";

//将时间戳转换为可读时间
//
$date = new DateTime('@1408950651');

$date->setTimezone(new DateTimeZone('Asia/Shanghai'));
echo $date->format('Y-m-d H:i:s');
echo "\n";

//或者
$date = new DateTime();
$date->setTimestamp(1408950651);
echo $date->format('Y-m-d H:i:s');

日期的比较
//4. 日期的比较
//日期大小比较
$date1 = new DateTime();
$date2 = new DateTime('2016-12-15');

if($date1 < $date2) {
    echo $date2->format('Y-m-d H:i:s') . ' is in the future';
}

///日期间隔
$date1 = new DateTime();
$date2 = new DateTime('2016-12-15');

$diff = $date1->diff($date2);
//print_r($diff);
//格式化输出
echo $diff->format("The future will come in %Y years %m months and %d days");

php使用生成器读取超大文件

<?php function getLines($file) { $f = fopen($file, 'r'); try { while ($line = fgets($f)) { yield $line; ...

阅读全文

php获取字符串里面的图片,xpath方式

代码 <?php $html = <<<str <html> <head> <title>123</title> </head> <body> <img src=&quo...

阅读全文

Thinkphp5 in查询结果按照in里面的顺序排

或许有人会注意过,但我以前真不知道 SQL: select * from table where id IN (3,6,9,1,2,5,8,7); 这样的情况取出来后,其实,id还是按1,2,3,4,5,6,7,8,9,排序...

阅读全文

评论已经关闭。