API:Bilder
Diese Seite ist Teil der Dokumentation der MediaWiki action API. |
MediaWiki Version: | ≥ 1.11 |
GET-Abfrage um auf den angegebenen Seiten eingebundene Medien-Dateien aufzulisten.
Dieses Modul kann als Generator benutzt werden.
API-Dokumentation
Beispiel
GET-Anfrage
In der Abfrage unten rufen wir die API an, um eine Liste von Bildern zu erhalten, die in die Seite Albert Einstein der englischsprachigen Wikipedia eingebunden sind.
api.php? action=query& titles=Albert%20Einstein& format=json& prop=images [In der ApiSandbox ausprobieren]
Antwort
{
"continue": {
"imcontinue": "736|Albert_Einstein_signature_1934.svg",
"continue": "||"
},
"query": {
"pages": {
"736": {
"pageid": 736,
"ns": 0,
"title": "Albert Einstein",
"images": [
{
"ns": 6,
"title": "File:1919 eclipse positive.jpg"
},
{
"ns": 6,
"title": "File:Albert Einstein's exam of maturity grades (color2).jpg"
},
{
"ns": 6,
"title": "File:Albert Einstein (Nobel).png"
},
...
]
}
}
}
}
Beispielcode
Python
#!/usr/bin/python3
"""
get_page_images.py
MediaWiki API Demos
Demo of `Images` module: Send a GET request to obtain a JSON
object listing all of the image files embedded on a single page
MIT License
"""
import requests
S = requests.Session()
URL = "https://en.wikipedia.org/w/api.php"
PARAMS = {
"action": "query",
"format": "json",
"titles": "Albert Einstein",
"prop": "images"
}
R = S.get(url=URL, params=PARAMS)
DATA = R.json()
PAGES = DATA['query']['pages']
for k, v in PAGES.items():
for img in v['images']:
print(img["title"])
PHP
<?php
/*
get_page_images.php
MediaWiki API Demos
Demo of `Images` module: Send a GET request to obtain a JSON
object listing all of the image files embedded on a single page
MIT License
*/
$endPoint = "https://en.wikipedia.org/w/api.php";
$params = [
"action" => "query",
"prop" => "images",
"titles" => "Albert Einstein",
"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"]["pages"] as $k => $v ) {
foreach( $v["images"] as $k => $v ) {
echo( $v["title"] . "\n" );
}
}
JavaScript
/*
get_page_images.js
MediaWiki API Demos
Demo of `Images` module: Send a GET request to obtain a JSON
object listing all of the image files embedded on a single page
MIT License
*/
var url = "https://en.wikipedia.org/w/api.php";
var params = {
action: "query",
prop: "images",
titles: "Albert Einstein",
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 pages = response.query.pages;
for (var page in pages) {
for (var img of pages[page].images) {
console.log(img.title);
}
}
})
.catch(function(error){console.log(error);});
MediaWiki JS
/*
get_page_images.js
MediaWiki API Demos
Demo of `Images` module: Send a GET request to obtain a JSON
object listing all of the image files embedded on a single page
MIT License
*/
var params = {
action: 'query',
prop: 'images',
titles: 'Albert Einstein',
format: 'json'
},
api = new mw.Api();
api.get( params ).done( function ( data ) {
var pages = data.query.pages,
page;
for ( page in pages ) {
pages[ page ].images.forEach( function ( img ) {
console.log( img.title );
} );
}
} );
Demo-App(s)
Parametergeschichte
- v1.13: Eingeführt
imcontinue
,imlimit
- v1.18: Eingeführt
imimages
- v1.19: Eingeführt
imdir
Siehe auch
- API:Bildinfo - Erhält Informationen für alle Titel im Bild-Namensraum. Wird möglicherweise ersetzt durch
prop=fileinfo
. - API:Stashbildinfo - Erhält Informationen für Stash-Bilder oder -Dateien in dem Namensraum. Ausgabe ist identisch mit API:Bildinfo .
- API:Bildnutzung - Findet alle Seiten, die die angegebenen Bilder nutzen.
- API:Dateiduplikate - Listet alle Duplikate der gegebenen Bilder oder Dateien auf.
- API:Alle Bilder - Listet alle Bilder nach Titel oder Zeitstempel auf.