¿Cómo publicar publicaciones entre una fecha y hoy?


10

¿Es una forma de publicar publicaciones entre una fecha y hoy query_posts()?

Ejemplo: todas las publicaciones publicadas desde el 01/04/2012

Gracias

EDITAR:

¿Cómo agregar la fecha de filtro en esta publicación de consulta?

query_posts( array(  
    array('post'),
    'tax_query' => array(
        array(
            'taxonomy' => 'post_format',
            'field' => 'slug',
            'terms' => array('post-format-image')
        )
    ),
    'cat' => '-173',
    'post_status' => 'publish'
) );


No use query_posts (). Comprueba esto -> wordpress.stackexchange.com/a/1755/7890
moraleida

Respuestas:


23

ACTUALIZACIÓN 23 de diciembre de 2014

Hay un mejor método usando la date_querypropiedad de WP_Queryclase:

$args = array(
    'post_type' => 'post', 
    'tax_query' => array(
        array( 
            'taxonomy'  => 'post_format',
            'field'     => 'slug',
            'terms'     => array( 'post-format-image' )
        )
    ),
    'cat'           => '-173',
    'post_status'   => 'publish',
    'date_query'    => array(
        'column'  => 'post_date',
        'after'   => '- 30 days'
    )
);
$query = new WP_Query( $args );

ANTIGUA RESPUESTA

Utilice los parámetros de tiempo en WP_Query ()

Ejemplo de cita del Codex:

Regresar publicaciones de los últimos 30 días:

// This takes your current query, that will have the filtering part added to.
$query_string = array(
    'post_type' => 'post', 
    'tax_query' => array(
        array(
            'taxonomy'  => 'post_format',
            'field'     => 'slug',
            'terms'     => array( 'post-format-image' )
        )
    ),
    'cat'           => '-173',
    'post_status'   => 'publish'
);

// Create a new filtering function that will add our where clause to the query
function filter_where( $where = '' ) {
    // posts in the last 30 days
    $where .= " AND post_date > '" . date( 'Y-m-d', strtotime( '-30 days' ) ) . "'";
    return $where;
}

add_filter( 'posts_where', 'filter_where' );
$query = new WP_Query( $query_string );
remove_filter( 'posts_where', 'filter_where' );

Editar (en respuesta a la pregunta actualizada del OP).

Evita usar query_posts . Puede utilizar la técnica anterior para modificar su consulta principal (sujeto a algunos condicionales adicionales : es la página de inicio, es una página llamada 'foobar', etc.):

function wpse52070_filter_where( $where = '' , $query ) {
   if( $query->is_main_query() && is_page( 'foobar' ) ){
      // posts in the last 30 days
      $where .= " AND post_date > '" . date( 'Y-m-d', strtotime( '-30 days' ) ) . "'";
   }

    return $where;
}
add_filter( 'posts_where', 'wpse52070_filter_where' );

Okay ! Entonces el filtro ya está adentro $query_string. Pero, ¿cómo funciona con mis argumentos en Query_Posts? (Mira mi edición @Moraleida)
Steffi

1
@Steffi: vea la respuesta actualizada. Espero que no te importe la adición, Moraleida.
Stephen Harris

1
acaba de agregar su consulta actual, para que pueda deshacerse de query_posts de inmediato. :) ¡Y gracias @StephenHarris por la rápida actualización!
moraleida

Gracias @moraleida! Increíble ! Sólo una cosa. Dijiste: "Evita usar query_posts". Pero es mejor usarlo query_posts()en archivos de plantillas (como home.php ) que new WP_Query(), ¿no?
Steffi

Realmente no. query_postsdebe usarse solo para alterar el ciclo principal, y mucha gente argumenta que ni siquiera entonces (también hay un the pre_get_postsfiltro para eso). A menudo me encuentro usando solo WP_Queryo get_postspara todas mis consultas, ya que son independientes y se pueden usar varias veces sin interferir con nada más. Consulte las respuestas vinculadas en sus comentarios para obtener una explicación detallada. :)
moraleida

3

A partir de 3.7 puede usar date_query http://codex.wordpress.org/Class_Reference/WP_Query#Date_Parameters

Entonces los argumentos pasados ​​se verían así:

$query_string = array(
      'post_type' => 'post', 
      'date_query' => array(
        'after' => '2012-04-01' 
      ),
      'tax_query' => array(
          array( 
             'taxonomy' => 'post_format',
             'field' => 'slug',
             'terms' => array('post-format-image')
          )
      ),
      'cat' => '-173',
      'post_status' => 'publish'
);

0

Si desea obtener publicaciones entre dos fechas, use los parámetros antes y después en el parámetro date_query,

$query_string = array(
  'post_type' => 'post', 
  'date_query' => array(
    'column' => 'post_date',
    'after' => '2012-04-01',
    'before' => '2012-04-30' 
  ),
  'tax_query' => array(
      array( 
         'taxonomy' => 'post_format',
         'field' => 'slug',
         'terms' => array('post-format-image')
      )
  ),
  'cat' => '-173',
  'post_status' => 'publish'
);
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.