10

我正在寻找一个 PHP,它可以生成用户友好的时间表示 - 例如时间戳为time() - 2 * 3600.

有几个现有问题的答案和博客文章(123),但都只包含代码片段 - 不是我可以安装和升级的库。

Django 有一个,Python 也有一个独立的库,Javascript 也有几个(1、2、3 —— PHP库在哪里?


一个库应该有以下内容:

  • 文件
  • 梨可安装
  • 定期发布
  • (可选)翻译
4

4 回答 4

7

由于似乎没有任何库,我自己制作了一个并将其包含在 PEAR 中:

Date_HumanDiff , http://pear.php.net/package/Date_HumanDiff

代码位于http://github.com/pear/Date_HumanDiff

于 2012-04-17T11:46:50.433 回答
3

我知道Kohana有一个,你可以很容易地移植它。

该函数被调用fuzzy_span()

http://kohanaframework.org/3.3/guide-api/Date#fuzzy_span

于 2012-04-16T09:04:38.967 回答
1

Kohana Date 类fuzzy_span()为此提供了方法。但它无法回复您确切的值,例如“10 分钟”

于 2012-04-16T09:07:12.340 回答
0

试试这个代码:

$current_date_time_get_updated_on_date_format = '';

function get_updated_on_date_format($dt_updated, $prefix = 'Updated ', $at = 'at ') {
    global $current_date_time_get_updated_on_date_format;

    if ($current_date_time_get_updated_on_date_format == '') {
        $current_date_time_get_updated_on_date_format = now();
    }

    $i_second_now         = strtotime($current_date_time_get_updated_on_date_format);
    $i_second_dt_updated  = strtotime($dt_updated);
    $i_second_diff        = $i_second_now - $i_second_dt_updated;
    $s_return_date_format = '';

    if ($i_second_diff < 0) {
        // Developers Uploading Time, Time Zone Gap Patch
        $s_return_date_format = $prefix . $at . date('g:ia \o\n F jS, Y', strtotime($dt_updated));
    } else if ($i_second_diff < 60) {
        $s_return_date_format = $prefix . $i_second_diff . ' seconds ago ';
    } elseif ($i_second_diff < (60 * 60)) {
        $s_return_date_format = $prefix . round(($i_second_diff / 60), 0) . ' minitues ago ';
    } elseif ($i_second_diff < (60 * 60 * 24)) {
        $s_return_date_format = $prefix . round(($i_second_diff / (60 * 60)), 0) . ' hours ago ';
    } else {
        $s_return_date_format = $prefix . $at . date('g:ia \o\n F jS, Y', strtotime($dt_updated));
    }

    return $s_return_date_format;

}

function now() {
    // it should extract database time in this format 'YYYY-MM-DD HH:MM:SS'
    return mysql_now_value;
}
于 2012-04-16T09:13:41.137 回答