API:利用者の投稿記録
このページは MediaWiki 操作 API の説明文書の一部です。 |
MediaWiki バージョン: | ≧ 1.9 |
利用者の投稿記録を列挙する GET リクエストです。
APIの説明文書
例
GET 申請
User:Jimbo Wales の投稿記録を列挙します
レスポンス
{
"batchcomplete": "",
"continue": {
"uccontinue": "20190130180447|880978627",
"continue": "-||"
},
"query": {
"usercontribs": [
{
"userid": 24,
"user": "Jimbo Wales",
"pageid": 9870625,
"revid": 881893498,
"parentid": 881892978,
"ns": 3,
"title": "User talk:Jimbo Wales",
"timestamp": "2019-02-05T14:05:11Z",
"comment": "/* Fancy I edit Wikipedia T-Shirt */",
"size": 29753
},
{
"userid": 24,
"user": "Jimbo Wales",
"pageid": 9870625,
"revid": 881282261,
"parentid": 881270759,
"ns": 3,
"title": "User talk:Jimbo Wales",
"timestamp": "2019-02-01T15:29:31Z",
"comment": "/* Macedonian President Gorge Ivanov is now in the House arrest */",
"size": 60166
},
{
"userid": 24,
"user": "Jimbo Wales",
"pageid": 9513191,
"revid": 881245934,
"parentid": 881240310,
"ns": 1,
"title": "Talk:Mark Dice",
"timestamp": "2019-02-01T09:48:38Z",
"comment": "/* So good they names it twice */",
"size": 74128
},
...
]
}
}
サンプル コード
Python
#!/usr/bin/python3
"""
get_usercontribs.py
MediaWiki API Demos
Demo of `Usercontribs` module: List user contributions.
MIT License
"""
import requests
S = requests.Session()
URL = "https://en.wikipedia.org/w/api.php"
PARAMS = {
"action": "query",
"format": "json",
"list": "usercontribs",
"ucuser": "Jimbo Wales"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
USERCONTRIBS = DATA["query"]["usercontribs"]
for uc in USERCONTRIBS:
print(uc["title"])
PHP
<?php
//This file is autogenerated. See modules.json and autogenerator.py for details
/*
get_usercontribs.php
MediaWiki API Demos
Demo of `Usercontribs` module: List user contributions.
MIT License
*/
$endPoint = "https://en.wikipedia.org/w/api.php";
$params = [
"action" => "query",
"format" => "json",
"list" => "usercontribs",
"ucuser" => "Jimbo Wales"
];
$url = $endPoint . "?" . http_build_query( $params );
$ch = curl_init( $url );
curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );
$output = curl_exec( $ch );
curl_close( $ch );
$result = json_decode( $output, true );
foreach( $result["query"]["usercontribs"] as $k => $v ) {
echo( $v["title"] . "\n" );
}
JavaScript
/*
get_usercontribs.js
MediaWiki API Demos
Demo of `Usercontribs` module: List user contributions.
MIT License
*/
var url = "https://en.wikipedia.org/w/api.php";
var params = {
action: "query",
format: "json",
list: "usercontribs",
ucuser: "Jimbo Wales"
};
url = url + "?origin=*";
Object.keys(params).forEach(function(key){url += "&" + key + "=" + params[key];});
fetch(url)
.then(function(response){return response.json();})
.then(function(response) {
var usercontrib = response.query.usercontribs;
for (var uc in usercontrib) {
console.log(usercontrib[uc].title);
}
})
.catch(function(error){console.log(error);});
MediaWiki JS
/*
get_usercontribs.js
MediaWiki API Demos
Demo of `Usercontribs` module: List user contributions.
MIT License
*/
var params = {
action: 'query',
format: 'json',
list: 'usercontribs',
ucuser: 'Jimbo Wales'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
var usercontrib = data.query.usercontribs,
uc;
for ( uc in usercontrib ) {
console.log( usercontrib[ uc ].title );
}
} );
起こりうるエラー
コード | 情報 |
---|---|
invaliduserid | User ID username is not valid. |
paramempty_ucuser | The parameter user may not be empty. |
baduser_ucuser | Invalid value "username" for user parameter user. |
show | Incorrect parameter - mutually exclusive values may not be supplied. |
permissiondenied | You need the patrol or patrolmarks right to request the patrolled flag.
|
パラメーターの履歴
- v1.39:
uciprange
を導入しました - v1.29:
ucuserids
を導入しました - v1.23:
uctoponly
を廃止予定にしました - v1.23:
ucshow=top
,ucshow=!top
,ucshow=new
,ucshow=!new
を導入しました - v1.20:
ucprop=sizediff
を導入しました - v1.18:
uctoponly
を導入しました - v1.16:
ucprop=parsedcomment
,ucprop=size
,ucprop=tags
,uctag
を導入しました - v1.15:
ucprop=patrolled
,ucshow=patrolled
,ucshow=!patrolled
を導入しました - v1.14:
uccontinue
を導入しました - v1.13:
ucuserprefix
を導入しました - v1.11:
ucnamespace
,ucprop
,ucshow
を導入しました
その他の注記
- このモジュールはページの編集と移動(改名)を返しますが、アップロードなど、その他の編集操作は対象外です。
- MediaWiki v1.14 以前は、返答結果内で
start
パラメータを使ってその他の結果を抽出しました。 v1.14 から v1.22, まで、start
は1個人の投稿記録を一覧にする場合に継続して有効でした。continue
は複数の人に関して投稿一覧を得るために採用しました。 v1.23 以降、クエリはすべてcontinue
を採用。
関連項目
- API:記録項目 - さまざまな活動を表示、アップロードも対象