WordPress 获取今天/最近24小时发布的文章数量

获取最近24小时发布的文章数

注:最近24小时 – 是从用户当前的时间算起,往前24小时,这个时间段发布的数量。不一定全部是今天,也有可能是昨天某个时间的。

/**
 * [get_posts_count_from_last_24h 获取最近24小时内发布的文章数量]
 * https://www.ymku.vip
 * @param  string $post_type [参数默认为 post 这个类型,你可以填写其他文章类型]
 */
function get_posts_count_from_last_24h($post_type ='post') {
    global $wpdb;
    $numposts = $wpdb->get_var(
        $wpdb->prepare(
            "SELECT COUNT(ID) ".
            "FROM {$wpdb->posts} ".
            "WHERE ".
                "post_status='publish' ".
                "AND post_type= %s ".
                "AND post_date> %s",
            $post_type, date('Y-m-d H:i:s', strtotime('-24 hours'))
        )
    );
    return $numposts;
}

将上面的代码添加到当前主题的 functions.php ,然后在你需要调用的地方使用下面的代码即可:

<?php echo get_posts_count_from_last_24h(); ?>

默认为“post”这个文章类型,如果你要调用其他文章类型,比如 book,可以这样用:

<?php echo get_posts_count_from_last_24h('book'); ?>

获取今天发布的文章数

注:今天 – 也就是当天0点-24点。

/**
 * [get_posts_count_from_today 获取今天内发布的文章数量]
 * https://www.ymku.vip
 * @param  string $post_type [参数默认为 post 这个类型,你可以填写其他文章类型]
 */
function get_posts_count_from_today($post_type ='post') {
    global $wpdb;
    $numposts = $wpdb->get_var(
        $wpdb->prepare(
            "SELECT COUNT(ID) ".
            "FROM {$wpdb->posts} ".
            "WHERE post_status='publish' ".
                "AND post_type= %s ".
                "AND DATE_FORMAT(post_date, '%Y-%m-%d') = %s",
            $post_type, date('Y-m-d', time())
        )
    );
    return $numposts;
}

将上面的代码添加到当前主题的 functions.php ,然后在你需要调用的地方使用下面的代码即可:

<?php echo get_posts_count_from_today(); ?>

默认为“post”这个文章类型,如果你要调用其他文章类型,比如 book,可以这样用:

<?php echo get_posts_count_from_today('book'); ?>

具体参考以下链接:

http://wordpress.stackexchange.com/questions/106383/count-posts-or-custom-post-types-from-last-24-hours-or-from-today

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容