Drupal 7 无法以编程方式设置Drupal 7视图中日期的公开筛选器
我试图从我创建的视图中获取数据。我已经公开了nid和另一个名为uid的字段,当我对它们应用过滤器时,它们工作正常。然而,还有另一个公开的过滤器“field_date”,它在drupal的ui中工作,但在我的custome模块中不是以编程方式工作的。这是一个日期戳字段。我的代码示例如下。传递的值是unix时间戳格式Drupal 7 无法以编程方式设置Drupal 7视图中日期的公开筛选器,drupal-7,drupal-views,Drupal 7,Drupal Views,我试图从我创建的视图中获取数据。我已经公开了nid和另一个名为uid的字段,当我对它们应用过滤器时,它们工作正常。然而,还有另一个公开的过滤器“field_date”,它在drupal的ui中工作,但在我的custome模块中不是以编程方式工作的。这是一个日期戳字段。我的代码示例如下。传递的值是unix时间戳格式 views_include('view'); $name = Rest::$DAILY_LOGS_VIEW; $display = Rest::$DAILY_L
views_include('view');
$name = Rest::$DAILY_LOGS_VIEW;
$display = Rest::$DAILY_LOGS_VIEW_PAGE;
$alter = array('exposed' =>array('field_uid_value' => $uid));
if(!empty($nid)) $alter['exposed']['nid'] = (int) $nid;
//if(!empty($from_date)) $alter['exposed']['field_date_value_1']['min'] = (int) $from_date;
//if(!empty($to_date)) $alter['exposed']['field_date_value_1']['max'] = (int) $to_date;
//if(!empty($to_date)) $alter['exposed']['field_date_value_1[max]'] = (int) $to_date;
if(!empty($date)) $alter['exposed']['field_date_value'] = (int) $date;
$view = views_get_view($name);
$view->init_display($display);
$view->preview=TRUE;
$view->is_cacheable = FALSE;
if(isset($alter['exposed'])) {
foreach($alter['exposed'] as $key => $valor) {
$view->exposed_input[$key] = $valor;
}
}
$view->init_pager();
$view->pager['items_per_page'] = $count;
$view->pager['use_pager'] = true;
$view->display_handler->options['use_pager'] = true;
$view->set_items_per_page($count);
$view->pager['current_page'] = $page;
$view->pre_execute();
$output = $view->display_handler->preview();
$view->post_execute();
return $view->result;
我这里有两个问题
使用日期格式的过滤器的正确格式是什么
对于带有日期“介于”值(即最小值和最大值之间)的过滤器,其格式是什么?我遇到了同样的问题,并使用以下方法解决了此问题:
$view->exposed_input[$key]["value"]["month"] = $month;
$view->exposed_input[$key]["value"]["year"] = $year;
不确定是否也需要“天”,但我已经选择了粒度上的“月”第二部分的答案:为日期介于“最小值”和“最大值”之间的过滤器提供的格式: 我安装了日期模块,并将过滤器设置为
if(!empty($from_date)) $view->exposed_input['field_date_value']['min']['date']= $from_date;
if(!empty($to_date)) $view->exposed_input['field_date_value']['max']['date']= $to_date;