2014-10-03 107 views
0

我想获得两个日期之间的小时数,但它似乎没有给我正确的结果。了解PHP日期差异

global $wpdb; 
global $wp; 
$wp->query_vars['sp_date'] = "10/06/2014"; 
$wp->query_vars['sp_time_period'] = "2pm to 3pm"; 
// only process requests with "my-plugin=ajax-handler" 
    date_default_timezone_set('America/New_York'); 
    $date = false; 
    $time_span = false; 
    $dayoffs = false; 
    if(isset($wp->query_vars['sp_date'])) { 
     $date = $wp->query_vars['sp_date']; 
    } 
    if(isset($wp->query_vars['sp_time_period'])) { 
     $period = $wp->query_vars['sp_time_period']; 
    } 
    if(isset($wp->query_vars['get_dayoffs'])) { 
     $dayoffs = $wp->query_vars['get_dayoffs']; 
    } 
    $returnValue = 0; 
    if($date || $period) { 
     $hrs = 0; 
     if($date && !$returnValue) { 
      $_SESSION['sp_date'] = $date; 
      $returnValue = 1; 
     } 
     if($period && !$returnValue) { 
      $_SESSION['sp_time_period'] = $period; 
      $returnValue = 1; 
     } 
     if($_SESSION['sp_date']) { 
      $hrsTilNoonBool = 0; 
      $nToday = date("Y-m-d h:i:s"); 
      $deliveryDates = $_SESSION['sp_date']." 18:00:00"; 
      $deliveryDateNoon = $_SESSION['sp_date']." 12:00:00"; 

      $date1 = new DateTime($nToday); 
      $date2 = new DateTime($deliveryDates); 
      $date3 = new DateTime($deliveryDateNoon); 
      $diff = $date2->diff($date1); 
      $diffNoon = $date3->diff($date1); 
      $hrs = $diff->format('%H'); 
      $hrsTilNoon = $diffNoon->format('%h'); 
      if($hrsTilNoon) { 
       $hrsTilNoonBool = 1; 
      } 
     } 
     $settings = $wpdb->get_results("SELECT * FROM sp_settings WHERE id = 1"); 
     $content = '{"value":'.$returnValue.', "over_twentyfour":'.$hrs; 
     if(!$settings[0]->payment_id_before) 
      $settings[0]->payment_id_before = 53; 
     if(!$settings[0]->payment_id_after) 
      $settings[0]->payment_id_after = 54; 
     $content .= ',"payment_before":'.$settings[0]->payment_id_before.',"payment_after":'.$settings[0]->payment_id_after.',"before_afternoon":'. 
      $hrsTilNoonBool.'}'; 
    } 
    if($dayoffs) { 
     $dates = $wpdb->get_results("SELECT * FROM sp_date_blacklist"); 
     $datesArry = array(); 
     foreach($dates as $d) { 
      $datesArry[] = $d->date; 
     } 
     $content = json_encode($datesArry); 
    } 
    echo $content; 
    exit(); 

我第一次把一个目标日期$wp->query_vars['sp_date'] = "10/06/2014";然后我把今天的日期是2014年10月3日。

 $diff = $date2->diff($date1); 
     $diffNoon = $date3->diff($date1); 
     $hrs = $diff->format('%H'); 

日子说3是对的。但时间是14个小时?我很困惑。也许,也许我没有读一些正确

enter image description here

回答

1

尝试追加同时每个时间戳,例如'00:00:00'。当你取得今天的日期时,也需要现在的时间。创建日期默认为午夜。

1

你哪里不暧昧日期:

$d1 = '01/02/2013'; 
$d2 = '01-02-2013'; 

$ts1 = strtotime($d1); // 1357106400 
$ts2 = strtotime($d2); // 1359698400 

echo date('r', $ts1); // Wed, 02 Jan 2013 00:00:00 -0600 
echo date('r', $ts2); // Fri, 01 Feb 2013 00:00:00 -0600 

/ V.S. strtotime()中的-分隔符是否有重大区别。这是欧洲的dd-mm-yyyy v.s.美国mm/dd/yyyy

您应该使用date_create_from_format()和EXCPLICITLY指定输入日期字符串的格式。

+0

我不认为这是有区别的,而不是欧洲人。即使我改变值来匹配格式,它仍然给我不正确的通知。 – numerical25 2014-10-06 11:54:48