0

私はちょうどこの素晴らしいワードプレス機能を発見しました

<?php echo 'Number of posts published by user: ' . count_user_posts( ); ?>

ユーザーがカテゴリごとに行った投稿の数を円グラフで表示するグラフを作成するのに忙しい. (chars.js)

ユーザーが投稿した各カテゴリの値を取得できるループを作成する方法はありますか.

将来的に証明したいので、さらにカテゴリが追加された場合、このようなものを書きに行く必要はありません

<?php echo 'Number of posts published by user: ' . count_user_posts( 5 ); ?>
<?php echo 'Number of posts published by user: ' . count_user_posts( 7 ); ?>
<?php echo 'Number of posts published by user: ' . count_user_posts( 8 ); ?>

ユーザーがすべてのカテゴリに投稿した投稿の数のカテゴリ内訳を取得する方法はありますか

助けてくれてありがとう

4

3 に答える 3

1

このコードを試してください:

配列で必要なユーザーのタイプを設定するだけです。

<?php $args = array(
    'blog_id'      => $GLOBALS['blog_id'],
    'role'         => 'subscriber',//"Super Admin" or "Administrator" or "Editor" or "Author" or "Contributor"
    'meta_key'     => '',
    'meta_value'   => '',
    'meta_compare' => '',
    'meta_query'   => array(),
    'include'      => array(),
    'exclude'      => array(),
    'orderby'      => 'login',
    'order'        => 'ASC',
    'offset'       => '',
    'search'       => '',
    'number'       => '',
    'count_total'  => false,
    'fields'       => 'all',
    'who'          => ''
 ); 

php get_users( $args );

foreach ($blogusers as $user) { ?>
        <li>
            <?php $user_id = $user->ID ?>
            <?php echo 'Number of posts published by user: ' . count_user_posts( $user_id ); ?>                 
        </li>   
<?php } ?>

ありがとう。

于 2013-10-03T13:03:50.490 に答える
0

これが完成したコードです。みんなの助けに感謝します

<script type="text/javascript">
var pieData = [
                            <?php
                                $user_id = get_query_var('author');

                                $rand = array('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f');

                                //get all posts from author
                                $args = array(
                                    'post_type' => 'post',
                                    'author'=> $queried_object->ID
                                );

                                $the_query = new WP_Query( $args );

                                if ( $the_query->have_posts() ) :

                                    while ( $the_query->have_posts() ) : $the_query->the_post();

                                        //put categories in array
                                        $cat = get_the_category( get_the_ID() );
                                        $terms[] = $cat[0]->term_id;

                                    endwhile;

                                    wp_reset_query();
                                endif;

                                //count matching categories (array vals)
                                $countVal = array_count_values($terms);
                                foreach($countVal as $count){

                                    $color = '#'.$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)];

                                    echo "  {
                                            value: ".$count.",
                                            color:'".$color."'
                                            },";
                                }

                            ?>
                            ]
                            var myPie = new Chart(document.getElementById("piec").getContext("2d")).Pie(pieData);
                        </script>
于 2013-10-04T10:47:23.797 に答える