私は私のウェブサイトで先週(7日間)の5つの最高評価の投稿を表示しようとしています、しかし私はそれらを表示する方法を考え出すことができないようです。
これが私がこれまでに達成したことですが、うまくいかないようです。
<?php $slider_query = new WP_Query('posts_per_page=5&cat=3&orderby=highest_rated&order=desc'); ?>
<?php
$mylimit = 7 * 86400; //days * seconds per day
while ($slider_query->have_posts()) : $slider_query->the_post();
$post_age = date('U') - get_post_time('U');
if ($post_age < $mylimit) {
?>
//The Post
<?php } ?>
<?php endwhile;?>
Birgireの解決策に加えて、WordPress 3.7では、 日付パラメータ を使うことができます。
過去7日間の投稿を絞り込むには、引数を次のようにします。
$args = array(
'post_type' => 'post',
'post_status' => 'publish',
'orderby' => 'date',
'order' => 'DESC',
// Using the date_query to filter posts from last week
'date_query' => array(
array(
'after' => '1 week ago'
)
)
);
私はこれがWordPress Answersで何度も解決されたに違いないと思います。
WP_Query
については、Codexの Timeパラメータの例 の部分をチェックすることもできます。
これらのうちの2つはここにあります(あなたの必要性にわずかに修正)
例1:
// Create a new filtering function that will add our where clause to the query
function filter_where( $where = '' ) {
// posts in the last 7 days
$where .= " AND post_date > '" . date('Y-m-d', strtotime('-7 days')) . "'";
return $where;
}
add_filter( 'posts_where', 'filter_where' );
$slider_query = new WP_Query('posts_per_page=5&cat=3&orderby=highest_rated&order=desc');
remove_filter( 'posts_where', 'filter_where' );
例2:
// Create a new filtering function that will add our where clause to the query
function filter_where( $where = '' ) {
// posts for May 1 to March 8, 2013
$where .= " AND post_date >= '2013-05-01' AND post_date < '2013-05-8'";
return $where;
}
add_filter( 'posts_where', 'filter_where' );
$slider_query = new WP_Query('posts_per_page=5&cat=3&orderby=highest_rated&order=desc');
remove_filter( 'posts_where', 'filter_where' )
上記のコメントで説明したように、このorderby=highest_rated
が何らかのプラグインで覆われていると仮定します。
このように私のために働いて、過去の7日間からの投稿を表示回数と投稿順に基づいて表示するにはDESCを数えます。
$date_range = strtotime ( '-7 day' );
$args = array(
'post_type' => 'post',
'post_status' => 'publish',
'posts_per_page' => '10',
'meta_key' => 'post_views_count',
'orderby' => 'meta_value_num',
'order' => 'DESC',
'date_query' => array(
array(
'after' => array(
'year' => date('Y', $date_range ),
'month' => date('m', $date_range ),
'day' => date('d', $date_range ),
),
)
)
);
$query = new WP_Query( $args );
WP_Query
時間パラメータ セクションから:
今週だけの投稿を返します。
$week = date('W');
$year = date('Y');
$query = new WP_Query( 'year=' . $year . '&w=' . $week );