Drupal 7 无法以编程方式设置Drupal 7视图中日期的公开筛选器

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

我试图从我创建的视图中获取数据。我已经公开了nid和另一个名为uid的字段,当我对它们应用过滤器时,它们工作正常。然而,还有另一个公开的过滤器“field_date”,它在drupal的ui中工作,但在我的custome模块中不是以编程方式工作的。这是一个日期戳字段。我的代码示例如下。传递的值是unix时间戳格式

    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;