Asial Blog

Recruit! Asialで一緒に働きませんか?

日本語版「Stack Overflow」のAPIを利用してみた!

カテゴリ :
バックエンド(プログラミング)
タグ :
入門
WebAPI
こんにちは、渡辺です。
去年12月16日に「Stack Overflow」の日本語版がパブリックベータとして公開されましたね。
公開からちょうど一ヶ月の1月16日(20時現在)の利用状況は下記のとおりで、質問すると高確率で回答がもらえるんですね。

 ユーザー数:5458人
 質問数:782件
 未回答質問:92件

今回は、今後ますます活発化する日本語版「Stack Overflow」をAPIで扱う方法を紹介します。
利用方法は簡単です。Stack Overflowからの情報取得だけであれば、API利用のための登録作業も必要ありません。
また、APIに問い合わせるURLは「StackExchange api」で作成することができます。下記の紹介もStackExchange apiで作成していきます。

■特定のタグを持つ質問を取得する


今回は「javascript」タグを持つ質問を取得したいと思います。
まず、https://api.stackexchange.com/docs/questionsにアクセスして、tagged欄に「javascript」を入力します。



このまま「Run」ボタンをクリックすると英語版「Stack Overflow」の結果が返ってきてしまうので、リンクをクリックして、新規タブを開き、URLの「site=stackoverflow」を「site=ja.stackoverflow」に変更します。

この手順で下記のURLが作成されました。

【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?order=desc&sort=activity&tagged=javascript&site=ja.stackoverflow

これだけで、「javascript」タグが付いている質問が取得できました。
(※下記はページの都合上1件に絞った結果です。)
  1. {
  2.     items: [
  3.         {
  4.             tags: [
  5.                 javascript
  6.                 ,css
  7.                 ,jquery
  8.             ]
  9.             ,owner: {
  10.                 user_type: does_not_exist (string)
  11.                 ,display_name: user7487 (string)
  12.             }
  13.             ,is_answered: false (boolean)
  14.             ,view_count: 21 (number)
  15.             ,answer_count: 0 (number)
  16.             ,score: 1 (number)
  17.             ,last_activity_date: 1421460965 (number)
  18.             ,creation_date: 1421459774 (number)
  19.             ,last_edit_date: 1421460965 (number)
  20.             ,question_id: 4715 (number)
  21.             ,link: http://ja.stackoverflow.com/questions/4715/jquery-%e3%81%a7-%e3%82%b9%e3%82%af%e3%83%ad%e3%83%bc%e3%83%ab%e8%bf%bd%e5%be%93%e5%9e%8b%e3%81%ab%e3%83%a1%e3%83%8b%e3%83%a5%e3%83%bc%e3%82%92%e3%82%ab%e3%82%b9%e3%82%bf%e3%83%9e%e3%82%a4%e3%82%ba%e3%81%97%e3%81%9f%e3%81%84 (string)
  22.             ,title: jQuery で、スクロール追従型にメニューをカスタマイズしたい (string)
  23.         }
  24.     ]
  25.     ,has_more: true (boolean)
  26.     ,quota_max: 300 (number)
  27.     ,quota_remaining: 205 (number)
  28. }

■取得する質問件数を増やす


次は、ページングを使って取得件数を変更しようと思います。
APIメソッドで取得できる件数は、初期状態では30件となっていますが、最大件数である100件を取得したいので、「pagesize」を100に設定します。また、次の100件を取得する場合は、「page」を2に設定します。



【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&order=desc&sort=activity&tagged=javascript&site=ja.stackoverflow

■期間を指定して取得する


期間を指定して質問を取得します。今回は、一ヶ月以内の質問を取得するようにしました。
「fromdate」と「todate」を設定するだけです。



【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&fromdate=1418688000&todate=1421366400&order=desc&sort=activity&tagged=javascript&site=ja.stackoverflow

■人気順で質問を取得する


apiで用意されているソートを利用することで、
日本語版StackOverflowトップページの「人気」タブと同じ結果を取得することができます。



【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&fromdate=1418688000&todate=1421366400&order=desc&sort=hot&tagged=javascript&site=ja.stackoverflow

ソートは6種類あり日本語版StackOverflowの記述に当てはめると、下のようになります。

・activity – アクティブ
・creation – 質問日時
・votes – 票数
・hot – 人気 (トップページのタブと同じソート(minとmaxは利用できないタイプのソート)
・week – 今週 (トップページのタブと同じソート(minとmaxは利用できないタイプのソート)
・month – 今月 (トップページのタブと同じソート(minとmaxは利用できないタイプのソート)

■質問だけでなく回答も取得する


「フィルター」を利用することによって、回答の取得ができるようになっています。フィルターの「edit」ボタンをクリックして、「answer」→「body」にチェックすることで取得できるようなります。



【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&fromdate=1418688000&todate=1421366400&order=desc&sort=hot&tagged=javascript&site=ja.stackoverflow&filter=!9YdnSM68i


また、フィルターには下記の種類が用意されているので、「withbody」を利用することでも回答内容を取得することができます。

 ・default : 各種の型が持っているデフォルトフィルターが適用される
 ・withbody : デフォルトフィルターと各種型のbodyフィールドが含まる
 ・none : 空が返却される
 ・total : totalフィールドが返却される


「withbody」を利用する場合は下記の内容となります。

【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&fromdate=1418688000&todate=1421366400&order=desc&sort=hot&tagged=javascript&site=ja.stackoverflow&filter=withbody

「total」を利用すると下のような結果が返ってきました。
  1. {
  2.     total: 63 (number)
  3. }

【リクエストURL】
  1. https://api.stackexchange.com/2.2/questions?page=1&pagesize=100&fromdate=1418688000&todate=1421366400&order=desc&sort=hot&tagged=javascript&site=ja.stackoverflow&filter=total

ちなみに、本家StackOverflowの利用状況をapiで問い合わせたところ、下の値が返ってきました。ユーザー数が300万人以上いるんですね。そして、1分あたりに約2件の質問と、4件の回答が投稿されているとは、スゴイです。日本語版も期待しています!!それでは!
  1. {
  2.     items: [
  3.         {
  4.             new_active_users: 24 (number)
  5.             ,total_users: 3854376 (number)
  6.             ,badges_per_minute: 3.61 (number)
  7.             ,total_badges: 12258396 (number)
  8.             ,total_votes: 57183608 (number)
  9.             ,total_comments: 40947181 (number)
  10.             ,answers_per_minute: 4.31 (number)
  11.             ,questions_per_minute: 2.55 (number)
  12.             ,total_answers: 14656651 (number)
  13.             ,total_accepted: 4958394 (number)
  14.             ,total_unanswered: 2222839 (number)
  15.             ,total_questions: 8681213 (number)
  16.             ,api_revision: 2015.1.16.13962 (string)
  17.         }
  18.     ]
  19.     ,has_more: false (boolean)
  20.     ,quota_max: 300 (number)
  21.     ,quota_remaining: 183 (number)
  22. }

【リクエストURL】
  1. https://api.stackexchange.com/2.2/info?site=stackoverflow