「利用者:芯/サンドボックス/6」の版間の差分
ナビゲーションに移動
検索に移動
3行目: | 3行目: | ||
==API リクエスト== | ==API リクエスト== | ||
===利用者別バイト数データ=== | ===利用者別バイト数データ=== | ||
利用者別に集計された執筆バイト数のデータを表で出力するリクエストです。122 行めと 123 行めを修正したうえで Python ファイル(拡張子: .py)として保存・実行すると、[[麻薬:データ#利用者別バイト数データ]]の内容を更新することができます。実行には Python と requests モジュールのインストールが必要です。 | |||
{{格納|名前='''ソースコード'''|中身= | {{格納|名前='''ソースコード'''|中身= | ||
46行目: | 46行目: | ||
logEvents.append(data["query"]["logevents"]) | logEvents.append(data["query"]["logevents"]) | ||
logEventsLen = len(logEvents) | logEventsLen = len(logEvents) | ||
IPUsers = { | IPUsers = { | ||
132行目: | 128行目: | ||
params = { | params = { | ||
"action": "login", | "action": "login", | ||
"lgname": | "lgname": [ここを自分のボット利用者名で置換], | ||
"lgpassword": | "lgpassword": [ここを自分のボットパスワードで置換], | ||
"lgtoken": LOGIN_TOKEN, | "lgtoken": LOGIN_TOKEN, | ||
"format": "json" | "format": "json" |
3年6月20日 (K) 00:43時点における版
利用者:芯/サンドボックス/6は、ソースコードを公開するページです。
API リクエスト
利用者別バイト数データ
利用者別に集計された執筆バイト数のデータを表で出力するリクエストです。122 行めと 123 行めを修正したうえで Python ファイル(拡張子: .py)として保存・実行すると、麻薬:データ#利用者別バイト数データの内容を更新することができます。実行には Python と requests モジュールのインストールが必要です。
ソースコード |
import requests import time import datetime import os import sys S = requests.Session() URL = "https://ja.wikiwiki.li/api.php" def getSize(page): params = { "action": "query", "prop": "revisions", "titles": page, "rvprop": "size", "format": "json" } data = S.get(url=URL, params=params).json() return list(data["query"]["pages"].items())[0][1]["revisions"][0]["size"] params = { "action": "query", "list": "logevents", "leprop": "title|user|timestamp", "leaction": "create/create", "lenamespace": 0, "lelimit": 500, "format": "json" } data = S.get(url=URL, params=params).json() logEvents = data["query"]["logevents"] while "continue" in data: time.sleep(0.5) params["lecontinue"] = data["continue"]["lecontinue"] data = S.get(url=URL, params=params).json() logEvents.append(data["query"]["logevents"]) logEventsLen = len(logEvents) IPUsers = { "172.70.223.86": "ひしょう", "60.145.16.169": "芯" } byteCntArrsByUser = { "Yuito": [], "MediaWiki default": [], "キュアラプラプ": [], "せうゆ": [], "Mapilaplap": [], "芯": [], "Popbob": [], "Notorious": [], "しんたろう": [], "Long谷": [], "神座麟": [], "ケツアゴコロロ": [], "ひしょう": [], "いせ": [], "デデ二オン": [], "MagnoliaWoolery": [], "210.151.113.170": [] } processed = 0 for le in logEvents: creator = le["user"] if creator not in byteCntArrsByUser: if creator in IPUsers: creator = IPUsers[creator] else: raise Exception("An unknown IP user.") byteCntArrsByUser[creator].append(getSize(le["title"])) time.sleep(0.5) processed += 1 print("\rlogEvents to byteCntArrsByUser: {:.2f}%".format( processed / logEventsLen * 100), end="") minMaxTtlAvg = {} for user, data in byteCntArrsByUser.items(): if data: ttl = sum(data) avg = round(ttl/len(data), 2) sortedData = sorted(data) min, max = sortedData[0], sortedData[-1] minMaxTtlAvg[user] = [ str(min) + " バイト", str(max) + " バイト", str(ttl) + " バイト", str(avg) + " バイト" ] else: minMaxTtlAvg[user] = None wTable = "{| class=\"wikitable sortable\" style=\"text-align: right;\"\n! 利用者名 !! style=\"width:7em;\" | 最小値 !! style=\"width:7em;\" | 最大値 !! style=\"width:7em;\" | 合計値 !! style=\"width:7em;\" | 平均値" for user, data in minMaxTtlAvg.items(): wTable += "\n|-\n! [[利用者:" + user + "|" + user + "]]" if data: wTable += "\n| " + data[0] + "\n| " + \ data[1] + "\n| " + data[2] + "\n| " + data[3] else: for i in range(4): wTable += "\n| style=\"text-align: center;\" | -" wTable += "\n|}" now = datetime.datetime.now() revisionNote = "最終更新日時: " + str(now.year) + "/" + str(now.month) + "/" + str( now.day) + "/" + str(now.hour) + ":" + str(now.minute) + ":" + str(now.second) + " 頃" wText = "==利用者別バイト数データ==\n本節では、各々の利用者が作成してきた標準記事(リダイレクトを除く)のバイト数について、その代表値を表示する。ソース: [[利用者:芯/サンドボックス/6#利用者別バイト数データ]]\n" + \ wTable + "\n" + revisionNote params = { "action": "query", "meta": "tokens", "type": "login", "format": "json" } LOGIN_TOKEN = S.get(url=URL, params=params).json()[ "query"]["tokens"]["logintoken"] params = { "action": "login", "lgname": [ここを自分のボット利用者名で置換], "lgpassword": [ここを自分のボットパスワードで置換], "lgtoken": LOGIN_TOKEN, "format": "json" } if S.post(URL, data=params).json()["login"]["result"] == "Failed": choice = input( "\rLogin faild. Still continue with your IP? [y/N]: ").lower() if choice in ["yes", "ye", "y"]: pass elif choice in ["no", "n"]: print("\nProcessing has been aborted.") sys.exit() params = { "action": "query", "meta": "tokens", "format": "json" } CSRF_TOKEN = S.get(url=URL, params=params).json()[ "query"]["tokens"]["csrftoken"] params = { "action": "edit", "title": "麻薬:データ", "section": 1, "text": wText, "summary": "利用者別バイト数データを更新", "bot": True, "token": CSRF_TOKEN, "format": "json" } print("\n" + str(S.post(URL, data=params).json())) |