API:QueryPage
Appearance
Diese Seite ist Teil der Dokumentation der MediaWiki action API. |
MediaWiki Version: | ≥ 1.18 |
GET-Abfrage um eine Liste zu erhalten, die von einer Spezialseite angeboten wird, die auf einer QueryPage basiert.
API-Dokumentation
Beispiel
GET-Anfrage
In der Abfrage unten rufen wir die API an, um eine Liste der ersten zehn Seiten zu erhalten, die nicht kategorisiert sind
api.php? action=query& format=json& list=querypage& qppage=Uncategorizedpages& qplimit=10 [In der ApiSandbox ausprobieren]
Antwort
{
"batchcomplete": "",
"continue": {
"continue": "-||",
"qpoffset": 10
},
"query": {
"querypage": {
"cached": "",
"cachedtimestamp": "2019-02-22T11:46:48Z",
"maxresults": 5000,
"name": "Uncategorizedpages",
"results": [
{
"ns": 0,
"title": "Abelardo Delgado",
"value": "0"
},
{
"ns": 0,
"title": "Agriculture in Tonga",
"value": "0"
},
{
"ns": 0,
"title": "Andriandramaka",
"value": "0"
}
...
]
}
}
}
Beispielcode
Python
#!/usr/bin/python3
"""
get_querypage_list.py
MediaWiki API Demos
Demo of `Querypage` module: List first 10 pages which are uncategorized
MIT License
"""
import requests
S = requests.Session()
URL = "https://en.wikipedia.org/w/api.php"
PARAMS = {
"qplimit": "10",
"action": "query",
"qppage": "Uncategorizedpages",
"list": "querypage",
"format": "json"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
QUERYPAGE = DATA['query']['querypage']['results']
for p in QUERYPAGE:
print(str(p['title']))
PHP
<?php
/*
get_querypage_list.php
MediaWiki API Demos
Demo of `Querypage` module: List first 10 pages which are uncategorized
MIT License
*/
$endPoint = "https://en.wikipedia.org/w/api.php";
$params = [
"action" => "query",
"list" => "querypage",
"qppage" => "Uncategorizedpages",
"qplimit" => "10",
"format" => "json"
];
$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"]["querypage"]["results"] as $page ){
echo( $page["title"] . "\n" );
}
JavaScript
/*
get_querypage_list.js
MediaWiki API Demos
Demo of `Querypage` module: List first 10 pages which are uncategorized
MIT License
*/
var url = "https://en.wikipedia.org/w/api.php";
var params = {
action: "query",
list: "querypage",
qppage: "Uncategorizedpages",
qplimit: "10",
format: "json"
};
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 querypage = response.query.querypage.results;
for (var p in querypage) {
console.log(querypage[p].title);
}
})
.catch(function(error){console.log(error);});
MediaWiki JS
/*
get_querypage_list.js
MediaWiki API Demos
Demo of `Querypage` module: List first 10 pages which are uncategorized
MIT License
*/
var params = {
action: 'query',
list: 'querypage',
qppage: 'Uncategorizedpages',
qplimit: '10',
format: 'json'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
var querypage = data.query.querypage.results,
p;
for ( p in querypage ) {
console.log( querypage[ p ].title );
}
} );
Spezialseitenwerte
(MediaWiki 1.32.0)
Ancientpages | Listredirects | Mostlinked | Unusedtemplates |
BrokenRedirects | Lonelypages | Mostrevisions | Unwatchedpages |
Deadendpages | Longpages | Shortpages | Wantedcategories |
DisambiguationPageLinks | MediaStatistics | Uncategorizedcategories | Wantedfiles |
DisambiguationPages | Mostcategories | Uncategorizedpages | Wantedpages |
DoubleRedirects | MostGloballyLinkedFiles | Uncategorizedimages | Wantedtemplates |
EntityUsage | Mostimages | Uncategorizedtemplates | Withoutinterwiki |
Fewestrevisions | Mostinterwikis | UnconnectedPages | |
GloballyWantedFiles | Mostlinkedcategories | Unusedcategories | |
ListDuplicatedFiles | Mostlinkedtemplates | Unusedimages |
Mögliche Fehler
Code | Information |
---|---|
unknown_qppage | Unrecognized value for parameter qppage: value. |
noqppage | The qppage parameter must be set. |
Zusätzliche Anmerkungen
- Dieses Modul kann als Generator benutzt werden.
- Die Filterung nach Namensräumen ist für diese Seiten nicht verfügbar. Ein möglicher Weg ist es, aus den erhaltenen Ergebnissen manuell "ns" zu filtern.
Siehe auch
- API:Alle Seiten - Listet alle Seiten in einem bestimmten Namensraum auf, die bestimmte Kriterien erfüllen.
- API:Kategorienmitglieder - Listet alle Seiten in einer Kategorie auf
- API:Seiten mit Eigenschaft - Listet alle Seiten mit einer bestimmten Seiteneigenschaft auf.