php-计算阵列循环中的行之间的日期(foreach)



我正在搜索如何在数组循环中计算值,一个foreach precselly。

问题是我必须计算此结果日期之间的天数。

示例:

<ul>
 <?php
   $values[] = array('example'=>'example1','date'=>'2016-25-12');
   $values[] = array('example'=>'example2','date'=>'2016-26-12');
   $values[] = array('example'=>'example3','date'=>'2016-28-12');
   $values[] = array('example'=>'example4','date'=>'2016-30-12');
 foreach($values[] as $example){
   echo "<li>".$example['example']." - ".$example['date']." - ".$DAYS BETWEEN EACH DATE$."</li>";
}
?>
</ul>

成为这样的事情:

  • 示例1-2016-25-12
  • 示例1-2016-26-12-1天
  • 示例1-2016-28-12-2天
  • 示例1-2016-30-12-2天
  • 如何进行此计算?*第一个什么也没显示,因为它是第一个寄存器。

    ty。

    我更改了您在数组中的日期的格式,因为YYYY-DD-MM未识别为有效格式,YYYY-MM-DD是。

    那么,这只是保存先前的值并计算天数的问题。

    <ul>
    <?php
    $values = array();
    $values[] = array('example' => 'example1', 'date' => '2016-12-25');
    $values[] = array('example' => 'example2', 'date' => '2016-12-26');
    $values[] = array('example' => 'example3', 'date' => '2016-12-28');
    $values[] = array('example' => 'example4', 'date' => '2016-12-30');
    $previous = null; // Define the variable
    foreach($values as $example){
        echo "<li>".$example['example']." - ".$example['date'];
        if ($previous !== null) { // If it's null, we're in the first loop
            $difference= strtotime($example['date'])-strtotime($previous);
            echo " - ".floor($difference/(60*60*24)); // $difference is in seconds, so convert to days by dividing by 60sec*60min*24hrs
        }
        $previous = $example['date']; // Set the current value, so it will be saved for the next iteration
        echo "</li>";
    }
    ?>
    </ul>
    

    上述输出将为

    • 示例1-2016-12-25
    • 示例2-2016-12-26-1
    • 示例3-2016-12-28-2
    • 示例4-2016-12-30-2

    demo

    $date = false;
    foreach($values as $item) {
      if ($date == false) {
        $date = $item['date'];
      } else {
        $datetime1 = new DateTime($date);
        $datetime2 = new DateTime($item['date']);
        $interval = $datetime1->diff($datetime2);
        echo $interval->format('%R%a days');
        $date = $item['date'];
      }
    }
    

    这样的东西。我没有检查语法,只是在fly上写

    <ul>
        <?php
        $values[] = array('example'=>'example1','date'=>'2016-25-12');
        $values[] = array('example'=>'example2','date'=>'2016-26-12');
        $values[] = array('example'=>'example3','date'=>'2016-28-12');
        $values[] = array('example'=>'example4','date'=>'2016-30-12');
        $date_prev = 0;
        foreach($values as $example){
            $parts = explode( '-', $example[ 'date' ]);
            $date_current =  strtotime($parts[0] . '/' . $parts[2] . '/' . $parts[1]); // year-month-day format
            $diff = $date_current - $date_prev;
            $DAYS_BETWEEN_EACH_DATE = intval($diff / 86400); // 86400 seconds in one day
            echo "<li>" . $example['example'] . " - " . $example['date'] . ($date_prev ? " - ". $DAYS_BETWEEN_EACH_DATE . ' day(s)' : '' ) . "</li>";
            $date_prev = $date_current;
        }
        ?>
    </ul>
    

    使用date_diff()函数,您也可以在几天内获得结果

    文档:http://php.net/manual/en/function.date-diff.php

    最新更新