我正在试图弄清楚如何从我设置的日期范围中排除某些日期。日期范围工作得很好:
<?php $newBegin = new DateTime('6/30/2010');
$newEnd = new DateTime('7/12/2010');
$newEnd = $newEnd->modify( '+1 day' );
$newDaterange = new DatePeriod($newBegin, new DateInterval('P1D'), $newEnd);
foreach($newDaterange as $newDate){
echo $newDate->format("jnY") . " ";
} ?>
打印结果如下:
3062010 172010 272010 372010 472010 572010 672010 772010 872010 972010 1072010 1172010 1272010
但客户需要从每个日期范围中排除某些日期,因此我最好输入日期:7/2/2010 7/4/2010 8/4/2010
并将其排除在日期范围之外。这是可能吗?我不打算排除周末等等,我可以这样做,只需输入一组日期并从日期范围中排除它们。任何建议将不胜感激!
更新
正如@ hek2mgl要求的那样,我添加了var_dump()
get_field('test_select'));
var_dump(get_field('test_select'));
结果:
array(2) { [0]=> string(8) "7/2/2010" [1]=> string(8) "
完整代码(不工作):
$newBegin = DateTime::createFromFormat('n/j/Y', '6/30/2010');
$newEnd = DateTime::createFromFormat('n/j/Y', '7/12/2010');
$newEnd = $newEnd->modify( '+1 day' );
$exclude = array();
// stores dates like so: 7/2/2010 7/3/2010
foreach(get_field('test_select') as $datestring) {
$exclude []= new DateTime($datestring);
}
$newDaterange = new DatePeriod($newBegin, new DateInterval('P1D'), $newEnd);
foreach($newDaterange as $newDate){
if(!in_array($newDate, $exclude)) {
echo $newDate->format("jnY") . " ";
}
}
答案 0 :(得分:3)
无法使用DatePeriod
类排除某个范围内的多个日期。但您可以将in_array()
与DateTime
对象一起使用。这可能会产生如下代码:
$newBegin = new DateTime('6/30/2010');
$newEnd = new DateTime('7/12/2010');
$newEnd = $newEnd->modify( '+1 day' );
$exclude = array(
new DateTime('7/2/2010'),
new DateTime('7/4/2010'),
new DateTime('8/4/2010')
);
$newDaterange = new DatePeriod($newBegin, new DateInterval('P1D'), $newEnd);
foreach($newDaterange as $newDate){
if(!in_array($newDate, $exclude)) {
echo $newDate->format("jnY") . " ";
}
}
输出:
3062010 172010 372010 572010 672010 772010 872010 972010 1072010 1172010 1272010
更新
在评论中,您已询问如何将日期字符串的传入列表转换为可在DateTime
数组中使用的$exclude
个对象。
示例:
$exclude = array();
// stores dates like so: 7/2/2010 7/3/2010
foreach(get_field('test_select') as $datestring) {
$exclude []= new DateTime::createFromFormat('n/j/Y', $datestring);
}
就是这样。 :)