将字符串转换为日期php

时间:2012-01-03 11:58:52

标签: php mysql

你好我想建立

我从表格xxx获得$ date和$ date1。我想做假期计划。

现在我想要使用值为xx-xx-xxxx(dd / mm / yyyy)的变量字符串处理$ date并且 现在我想将$ date1转换为日期。

我已经知道如何使用datediff()

计算一天

我转换$ date所以我可以使用dateadd()函数

这里是代码

$t1 = substr($date,0,2);
$b1 = substr($date,3,2);
$y1 = substr($date,6,4);

$t2 = substr($date11,0,2);
$b2 = substr($date1,3,2);
$y2 = substr($date1,6,4);

$tawal ="$y1-$b1-$t1";
$takhir = "$y2-$b2-$t2";

$query = "SELECT datediff('$takhir', '$tawal')as selisih";
$hasil = mysql_query($query);
$data = mysql_fetch_array($hasil);

$times = $data['selisih']; 
$times = + 1;
这是图片 enter image description here

2 个答案:

答案 0 :(得分:6)

您不需要substr或mysql。首先得到没有substr的日期:

$tawal = date('Y-m-d', strtotime($date));
$takhir = date('Y-m-d', strtotime($date1));

现在你有了Y-m-d格式的字符串。要找到差异,虽然你不必转换为Y-m-d,因为我们不需要mysql。您可以使用this method以秒为单位查找差异。

$diff = abs(strtotime($date2) - strtotime($date));
$years = floor($diff / (365*60*60*24));
$months = floor(($diff - $years * 365*60*60*24) / (30*60*60*24));
$days = floor(($diff - $years * 365*60*60*24 - $months*30*60*60*24)/ (60*60*24));

答案 1 :(得分:0)

以下是我的约会对象:

function date_as($date, $format = 'Verbal, hour:minute')
{
    parse_date($date);

    $format = str_replace(array('verbal', 'Verbal'), array($date['verbal'], $date['Verbal']), $format);

    return str_replace(array_keys($date), array_values($date), $format);
}

function parse_date(&$date)
{
    $unix   = is_numeric($date) ? $date : strtotime($date);

    $date = array(
        'month'     => strtolower(date('F', $unix)),
        'dayweek'   => strtolower(date('l', $unix)),
        'date'      => date('d', $unix),
        'year'      => date('Y', $unix),
        'hour'      => date('H', $unix),
        'minute'    => date('i', $unix),
        'second'    => date('s', $unix),
        'today'     => (date('Y-m-d',strtotime('now')) == date('Y-m-d', $unix)),
        'yesterday' => (date('Y-m-d', strtotime('now - 1 day')) == date('Y-m-d', $unix)),
        'tomorrow'  => (date('Y-m-d', strtotime('now + 1 day')) == date('Y-m-d', $unix)),
        'mint'      => date('m', $unix),
    );

    if ($date['yesterday'])
    {
        $date['verbal'] = 'yesterday';
    }
    elseif ($date['today'])
    {
        $date['verbal'] = 'today';
    }
    elseif ($date['tomorrow'])
    {
        $date['verbal'] = 'tomorrow';
    }
    else
    {
        $date['verbal'] = 'date month';
    }

    foreach (array('dayweek', 'month', 'verbal', 'date') as $p)
    {
        $date[ucfirst($p)] = mb_convert_case($date[$p], \MB_CASE_TITLE, 'UTF-8');
    }
}

格式,如您所愿...