0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

自分の書いたQiita記事の閲覧数を一覧でサクッと確認する手順作ってみました

Last updated at Posted at 2025-01-10

ごあいさつ

こんにちは、「エイジ@フジワーランド」です
フリーでパッケージシステムのOEM供給やってます、最近暇なので時給でSESやってます
昨日書いた記事がトレンドに入っていたようで…ありがとうございます!

さて今回はQiita記事閲覧数を簡単に確認する方法の話です

自分の書いたQiita記事の閲覧数をサクッと確認する方法

トレンド入りが嬉しく閲覧数を確認しようとしたら…Qiitaには記事ごとの閲覧数を一覧で表示する機能がないんですね、Qiita初心者なので今日気づきました
個別の記事を開けば閲覧数を確認できますが、それだと閲覧数が増えてしまいますし何より効率的ではありませんよね

そこで、記事ごとの閲覧数を一覧で簡単に表示する方法を作ってみました
Qiitaに慣れている方はすでにご自身で取得する方法をお持ちかもしれませんが、これから始める方や同じ悩みを抱える方のために手順をまとめておきます

書いてある手順どおりに進めれば、初回は3分程度、2回目以降は1秒で閲覧数を確認できるようになると思います(※効果には個人差がありますw)

手順

1. テキストエディタ開いて以下のコードを貼り付けます(保存する場合、拡張子は .py にしてください)

import requests
import webbrowser
import os

def fetch_qiita_articles(access_token):
    """Qiita APIから記事を取得"""
    base_url = "https://qiita.com/api/v2/authenticated_user/items"
    headers = {"Authorization": f"Bearer {access_token}"}
    articles, page = [], 1

    while True:
        response = requests.get(base_url, headers=headers, params={"page": page, "per_page": 100})
        if response.status_code != 200 or not (data := response.json()):
            break
        articles.extend(data)
        if len(articles) >= int(response.headers.get('Total-Count', 0)):
            break
        page += 1

    return articles

def generate_html(articles):
    """記事データをHTMLに変換して保存"""
    sorted_articles = sorted(articles, key=lambda x: x.get('page_views_count', 0), reverse=True)
    rows = "\n".join(
        f"<tr><td>{i + 1}</td><td>{a['title']}</td><td>{a.get('page_views_count', 0):,}</td><td>{a['created_at']}</td></tr>"
        for i, a in enumerate(sorted_articles)
    )
    html = f"""
    <html>
    <head>
        <title>Qiita 記事閲覧ランキング(上位100件)</title>
        <style>
            table {{ border-collapse: collapse; width: 80%; margin: 20px auto; }}
            th, td {{ border: 1px solid #ccc; padding: 8px; text-align: left; }}
            th {{ background-color: #f4f4f4; }}
        </style>
    </head>
    <body>
        <h1>Qiita 記事閲覧ランキング(上位100件)</h1>
        <table>
            <thead>
                <tr><th>順位</th><th>タイトル</th><th>閲覧数</th><th>作成日</th></tr>
            </thead>
            <tbody>{rows}</tbody>
        </table>
    </body>
    </html>
    """
    file_path = os.path.abspath("qiita_articles.html")
    with open(file_path, "w", encoding="utf-8") as f:
        f.write(html)
    return file_path

def main():
    access_token = "<自分のアクセストークン>"  # 自分のアクセストークンを入力
    articles = fetch_qiita_articles(access_token)
    webbrowser.open(f"file://{generate_html(articles)}")

if __name__ == "__main__":
    main()

2. Qiitaのアクセストークンの取得します ( すでに取得している人はスキップしてください )

  • Qiitaにログインした状態で右上の自分のアイコンをクリックすると出るメニューの設定を選択します
    image.png
     
  • 設定画面の左のメニューから アプリケーションを選択
    image.png
     
  • 個人用アクセストークン 新しくトークンを発行する をクリック
    image.png
     
  • アクセストークンの発行画面で、 アクセストークンの説明の入力をして、スコープは画像の通りで発行するをクリック
    image.png
     
  • アクセストークンをコピーする
    image.png

3. コード内のアクセストークンを書き換えてファイル保存します

  • テキストエディタに貼り付けたコードの「<自分のアクセストークン>」を、取得したアクセストークンに書き換えます
    image.png
     
  • テキストエディタに貼り付けたコードを保存( 拡張子は .py にしてください )

4. Pythonインストールします ( インストール済みの方はスキップ )

  • Python の公式サイト(https://www.python.org/)にアクセスし、最新版をダウンロード
    image.png
     
  • インストーラーを実行
    • ダウンロードしたファイルをダブルクリックしてインストールを開始します
    • 必ず「Add Python to PATH」にチェックを入れてからインストールしてください
      image.png
       
  • インストール完了時画面の「 Disable path length limit 」をクリックしてからクローズしてください
    image.png
     
  • PowerShell を開いて以下を実行
pip install requests beautifulsoup4 lxml

image.png

5. 実行します

  • 保存したファイルをpythonで開く
    image.png
     
    ※.pyファイルを pythonに関連付けておけばダブルクリックでOKですね
     
  • 実行結果
    image.png
    ※閲覧数少なくて恥ずかしいのでマスクしました

注意

  • .pyフォルダに qiita_articles.html っていうファイルを作成してそれを表示してます…気に入らない人は適当にカスタマイズしてください
  • 私の書いた記事数がまだまだ少なく、ランキング100位までの表示検証できてないです…すみません

おわりに

3分で手順最後まで行けましたでしょうか?
100位まで検証できてなくて申し訳ないですが悪さはしないコードなのでぜひ使ってみてください
みなさんの作業効率が少しでもあがることを願います

最後まで読んできただきありがとうございました

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?