腾讯云服务器优惠活动华纳云香港服务器

如何获取WordPress某个分类目录的文章数目?

WordPress主题推荐

一、使用 WordPress 内置函数 get_posts()

  1. <?php
  2. $posts = get_posts( ‘numberposts=-1&category=3’ );
  3. echo count($posts);
  4. ?>

二、使用 WordPress 内置函数 get_category_by_slug()

  1. <?php
  2. // 将以下’category-name’改成你的分类别名即可
  3. echo get_category_by_slug(‘category-name’)->count;
  4. ?>

三、使用 WordPress 内置函数 get_category()

  1. <?php
  2. // 将以下 cat_ID 改成你的分类 ID 即可
  3. echo get_category(cat_ID)->count;
  4. ?>

四、使用 WordPress 的内置函数 wp_list_categories()

  1. <?php echo strip_tags(wp_list_categories(‘include=3&hide_empty=0&use_desc_for_title =0&echo=0&show_count=1&style=none&hierarchical =0&title_li=’)); ?>

参数 include 的等号后面 3 改成你想要统计文章数的分类 ID 即可。最终输出形式为:分类名称(文章数) ,如图像印记(20)

五、使用 wpdb 直接查询数据库

将以下 PHP 代码放置在主题目录下的 functions.php 中

  1. function wt_get_category_count($input = ) {
  2.     global $wpdb;
  3.     if($input == ) {
  4.         $category = get_the_category();
  5.         return $category[0]->category_count;
  6.     }
  7.     elseif(is_numeric($input)) {
  8.         $SQL = “SELECT $wpdb->term_taxonomy.count FROM $wpdb->terms, $wpdb->term_taxonomy WHERE $wpdb->terms.term_id=$wpdb->term_taxonomy.term_id AND $wpdb->term_taxonomy.term_id=$input”;
  9.         return $wpdb->get_var($SQL);
  10.     }
  11.     else {
  12.         $SQL = “SELECT $wpdb->term_taxonomy.count FROM $wpdb->terms, $wpdb->term_taxonomy WHERE $wpdb->terms.term_id=$wpdb->term_taxonomy.term_id AND $wpdb->terms.slug=’$input'”;
  13.         return $wpdb->get_var($SQL);
  14.     }
  15. }

然后在需要的地方调用该函数即可,该函数提供三种调用方式:

1、在主循环中调出该函数,且不提供参数,则返回第一个分类的文章数:

  1. <?php echo wt_get_category_count(); ?>

2、提供的参数为数字,且该数字为分类的 ID 号,则返回对应 ID 的分类的文章数:

  1. <?php echo wt_get_category_count(1); ?>

3、提供分类的别名,则返回对应缩略名(别名)的分类文章数:

  1. <?php echo wt_get_category_count(‘hello-world’); ?>

该函数对于含有子分类的分类,文章数统计上会有稍许误差。对于分类文章数为 0 的情况统计得也不是很好。

以上内容整理自@511 遇见

本文地址:https://boke112.com/post/4277.html

赞 (0) 打赏
版权声明:本文为原创文章,版权归 boke112百科 所有,欢迎分享本文,转载请保留出处!发布此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请联系我们,确认后马上更正或删除,谢谢!
wu