2012-01-03 4 views
2

привет я хотел построитьконвертировать строку на сегодняшний день php

Я получаю $ date и $ date1 из формы xxx. Я хотел сделать отпуск.

Теперь я хотел обработать $ date с переменной строкой со значением xx-xx-xxxx (dd/mm/yyyy) и $ date1 со значением теперь я хочу преобразовать их на сегодняшний день.

Я уже знаю, как считать день, используя DATEDIFF()

я конвертировать $ дату, так что я могу использовать 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

ответ

6

Для этого вам не нужны substr или mysql. Сначала получите свои даты без подстраницы:

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

Теперь у вас есть строки в формате Y-m-d. Чтобы найти diff, хотя вам не нужно преобразовывать в 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)); 
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'); 
    } 
} 

формат, как вы хотите ...

Смежные вопросы