【问题标题】:Wordpress/PHP Get days between two dates and create arrayWordpress/PHP 获取两个日期之间的天数并创建数组
【发布时间】:2018-09-13 16:21:41
【问题描述】:

我有一个 custom-post-type 用于 Vacationperiods,其中有一些 Datepicker 类型的自定义字段来设置开始和结束日期。现在我想获取这些日期之间的所有日期并将它们添加到一个数组中。

function get_vacation_dates(){
global $post;

  $args = array(
    'post_type' => array('vacationperiods'),
    'post_status' => array('publish'),
    'order' => 'ASC'
  );

  $posts = get_posts($args);
  $vac = [];
  foreach ($posts as $post){

    $vacationTitle = get_field('name', $post->ID);
    $startDate = get_field('vacation_start', $post->ID);
    $endDate = get_field('vacation_end', $post->ID);

    // GET ALL DAYS/DATES
    for ($i=$startDate; $i<=$endDate; $i+=86400) {  
        $days = date('Y-m-d', $i);
    }       

    $duration = dateDiff($startDate, $endDate);

    $vac[] = [
        'name' => $vacationTitle,
        'start' => $startDate,
        'end' => $endDate,
        'duration' => $duration,
        'days' => $days
    ];



  }

  echo json_encode($days);

  die();
}

这种方法不起作用,它给了我"days: '1970-01-01'" - 但如前所述,我希望将所有日期列为一个数组,例如“days:['2018-09-13', '2018-09-14', etc..]

我怎样才能做到这一点?

【问题讨论】:

  • 将日期转换为strtotime。

标签: php arrays wordpress


【解决方案1】:

strtotime() 函数将英文文本 DateTime 解析为 Unix 时间戳(自 1970 年 1 月 1 日 00:00:00 GMT 以来的秒数)。

类似这样的:

$days = array();
    // GET ALL DAYS/DATES
        for ($i=strtotime($startDate); $i<=strtotime($endDate); $i+=86400) {  
            $days[] = date('Y-m-d', $i);
        } 

【讨论】:

  • 出于某种原因,这只会给我 endDate 作为结果:-/
  • 你的意思是循环的最后日期吗?
  • 没错,循环的最后日期
  • 其实$days是一个变量。它用最后一个值覆盖。它应该定义一个数组或者你想要的。
  • $days定义为数组$days = array();。查看更新的答案。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-03-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多