質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

1185閲覧

[wordpress]ユーザーごとのコメント数を取得して、ランキングとして表示

joe_tomo

総合スコア13

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/12/18 06:45

編集2017/12/18 06:48

こんにちわ
wordpressで、会員制サイトを構築していて、ユーザーが投稿したコメント数を取得してランキング表示をしたいです。
仕様は下記です。


・ユーザーのコメントした数が多い順に、10件まで
ユーザーランキングとして表示
・期間は、月間で取得したい

  1. ユーザーA 10件
  2. ユーザーB 8件
  3. ユーザーC 6件

上記のような情報の取得、表示は可能でしょうか
教えてください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

情報の取得、表示は可能でしょうか

不可能ではないです。
get_usersでユーザー情報を取得して、それぞれの投稿数をget_commentsのuser_idを指定してcountにtrueを指定すればそれぞれの投稿数が一覧できるので、それを並べ替えて表示すればランキングにはなります。

【get_users:WordPress私的マニュアル】
https://elearn.jp/wpman/function/get_users.html

【get_comments:WordPress私的マニュアル】
https://elearn.jp/wpman/function/get_comments.html

一発で取得するならSQLを駆使すれば出来るとは思います。

投稿2017/12/18 07:55

kei344

総合スコア69400

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

joe_tomo

2017/12/18 12:57

ありがとうございます! すいません、下記のように設定して、近づいてきたのですが 取得した、カウント数で並び替える方法をご教示いただけますでしょうか どうかお願いします ----------------------------- <?php $userslist = get_users(array( 'number' => 10)); foreach($userslist as $users): $user_id = $users->ID; $args = array( 'user_id' => $user_id, 'count' => true, 'date_query' => array( 'after' => '3 months ago', 'before' => 'today', 'inclusive' => true, ), ); $comments_count = get_comments( $args ); ?> <?php echo $comments_count; echo $name; ?> <?php endforeach; ?> ----------------------------- 結果 0 A 0 B 1 C 0 D 0 E 0 F 5 G ・ ・ ・ ------------------------------------ どうかお願いします
guest

0

こんな感じですかね?

  1. WP_User_Queryクラスでユーザー全件取得
  2. get_comments()にcountフラグを渡してそのユーザーの一ヶ月以内のコメント数取得
  3. ランキング配列に突っ込んでコメント数順でソート

コメント数が0の時は処理しないとか、ユーザー取得する時点でコメント0は弾くとかしたらもう少しスムーズな処理ができると思います。

PHP

1$users = new WP_User_Query(); 2if (!empty($users->results)) { 3 foreach ($users->results as $user) { 4 $args = array( 5 'author__in' => $user->ID, 6 'count' => true, 7 'date_query' => array( 8 'after' => '1 months ago', 9 'before' => 'today', 10 'inclusive' => true, 11 ), 12 ); 13 $count = get_comments($args); 14 $ranking[$user->user_nicename] = $count; 15 } 16 arsort($ranking); 17}

※動作確認してません

投稿2017/12/18 07:23

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問