API:Усі користувачі
Ця сторінка є частиною документації по MediaWiki Action API. |
Версія MediaWiki: | ≥ 1.11 |
Запит GET, щоб перерахувати всіх зареєстрованих користувачів у порядку за іменем користувача.
Документація API
Приклад
Запит GET
Запит GET для переліку всіх користувачів, починаючи з тих, чиє ім’я починається з рядка «Drov»
Відповідь
{
"batchcomplete": "",
"continue": {
"aufrom": "Drovark",
"continue": "-||"
},
"query": {
"allusers": [
{
"userid": 13239275,
"name": "Drov"
},
{
"userid": 7080866,
"name": "Drova"
},
{
"userid": 16013473,
"name": "Drova 82"
},
...
]
}
}
Приклад коду
Python
#!/usr/bin/python3
"""
get_allusers.py
MediaWiki API Demos
Demo of `Allusers` module: Get all users, starting from those whose name
begins with the string, 'Drov'.
MIT License
"""
import requests
S = requests.Session()
URL = "https://en.wikipedia.org/w/api.php"
PARAMS = {
"action": "query",
"format": "json",
"list": "allusers",
"auprefix": "Drov"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
USERS = DATA["query"]["allusers"]
for user in USERS:
print(user["name"])
PHP
<?php
/*
get_allusers.php
MediaWiki API Demos
Demo of `Allusers` module: Get all users, starting from those whose name begins with the string, 'Drov'.
MIT License
*/
$endPoint = "https://en.wikipedia.org/w/api.php";
$params = [
"action" => "query",
"format" => "json",
"list" => "allusers",
"auprefix" => "Drov"
];
$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"]["allusers"] as $k => $v ) {
echo( $v["name"] . "\n" );
}
JavaScript
/*
get_allusers.js
MediaWiki API Demos
Demo of `Allusers` module: Get all users, starting from those whose name begins with the string, 'Drov'.
MIT License
*/
var url = "https://en.wikipedia.org/w/api.php";
var params = {
action: "query",
format: "json",
list: "allusers",
auprefix: "Drov"
};
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 users = response.query.allusers;
for (var u in users) {
console.log(users[u].name);
}
})
.catch(function(error){console.log(error);});
MediaWiki JS
/*
get_allusers.js
MediaWiki API Demos
Demo of `Allusers` module: Get all users, starting from those
whose name begins with the string, 'Drov'.
MIT License
*/
var params = {
action: 'query',
format: 'json',
list: 'allusers',
auprefix: 'Drov'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
var users = data.query.allusers,
u;
for ( u in users ) {
console.log( users[ u ].name );
}
} );
Можливі помилки
Код | Інформація |
---|---|
augroup-excludegroup | group і excludegroup не можна використовувати разом |
Історія параметра
- v1.12: Введено
auprop=registration
Додаткові примітки
- Цей виклик API чутливий до регістру, тому
aufrom=DROV
не повертає ті ж результати, що йaufrom=Drov
. - Усі зареєстровані імена користувачів зберігаються та отримуються у вигляді великих літер. Якщо ви використовуєте
aufrom
абоauprefix
у своєму запиті, переконайтеся, що ви передаєте їм значення, які починаються з великого регістру. - Хоча поведінка за замовчуванням полягає в тому, щоб перерахувати будь-якого користувача в базі даних, ми також можемо обмежити нашу відповідь лише тими користувачами, які належать до певної групи, наприклад, адміністратор або боти. Групи користувачів – це те, як MediaWiki надає користувачам певні права та привілеї; див. Довідка:Права та групи користувачів , щоб дізнатися більше про роботу цієї системи.
Див. також
- API:Users - знаходить інформацію про список користувачів.