سؤال
أحاول استخدام date_diff()
:
$datetime1 = date_create('19.03.2010');
$datetime2 = date_create('22.04.2010');
$interval = date_diff($datetime1, $datetime2);
echo $interval->format('%R%d days');
لا يعمل بالنسبة لي ، يعطي خطأ:
Call to undefined function date_diff()
كيف يمكنني تشغيله؟
يستخدم PHP 5.2.
شكرًا.
المحلول
يتطلب الدالة Date_diff إصدار PHP من 5.3 أو أكثر.
تحديث
مثال على PHP 5.2 (مأخوذة من تعليقات مستخدم Date_diff).
<?php
function date_diff($date1, $date2) {
$current = $date1;
$datetime2 = date_create($date2);
$count = 0;
while(date_create($current) < $datetime2){
$current = gmdate("Y-m-d", strtotime("+1 day", strtotime($current)));
$count++;
}
return $count;
}
echo (date_diff('2010-3-9', '2011-4-10')." days <br \>");
?>
نصائح أخرى
فيما يلي إصدار لا يستخدم كائنات التاريخ ، ولكن لا يتم استخدامه على أي حال في 5.2.
function date_diff($d1, $d2){
$d1 = (is_string($d1) ? strtotime($d1) : $d1);
$d2 = (is_string($d2) ? strtotime($d2) : $d2);
$diff_secs = abs($d1 - $d2);
return floor($diff_secs / (3600 * 24));
}
function date_diff($date1, $date2) {
$count = 0;
//Ex 2012-10-01 and 2012-10-20
if(strtotime($date1) < strtotime($date2))
{
$current = $date1;
while(strtotime($current) < strtotime($date2)){
$current = date("Y-m-d",strtotime("+1 day", strtotime($current)));
$count++;
}
}
//Ex 2012-10-20 and 2012-10-01
else if(strtotime($date2) < strtotime($date1))
{
$current = $date2;
while(strtotime($current) < strtotime($date1)){
$current = date("Y-m-d",strtotime("+1 day", strtotime($current)));
$count++;
}
$current = $current * -1;
}
return $count; }
قم أولاً بتحويل كلا التواريخ إلى تنسيق mm/dd/yyyy ثم قم بذلك:
$DateDiff = floor( strtotime($datetime2 ) - strtotime( $datetime1 ) ) / 86400 ;
//this will yield the resultant difference in days
إن تحويل DateTime الخاص بك إلى نوع تاريخ Unix ، وطرح واحد من الآخر: التنسيق-> ("U") هو المكان الذي يتم فيه تحويل DateTime.
$datetime1 = date_create('19.03.2010');
$datetime2 = date_create('22.04.2010');
$intervalInDays = ($datetime2->format("U") - $datetime1->format("U"))/(3600 * 24);
لست متأكداً مما إذا كان هذا آمنًا Y2K38 ولكنه أحد أبسط حلول DATE_DIFF.
لا تنتمي إلى StackOverflow