Modul:Wikidata utilities/Doku
Erscheinungsbild
| Dies ist eine nachgeordnete Seite der Dokumentation von Modul:Wikidata utilities. Sie enthält Informationen zur Verwendung, Kategorisierung und zu anderem Inhalt, der nicht Bestandteil der originalen Modul-Seite ist. |
| Dieses Modul wird auf vielen Seiten benutzt, und Änderungen werden projektweit sofort wahrgenommen. Bitte teste Änderungen vorher im /Sandkasten oder in deinem Benutzernamensraum. Die getestete Änderung sollte dann in einem einzigen Edit auf dieser Seite eingefügt werden. Bitte diskutiere Änderungen zuerst auf der Diskussionsseite bevor du sie implementierst. |
| Dieses Modul ist getestet und für den projektweiten Gebrauch geeignet. Es kann in Vorlagen benutzt und auf Hilfeseiten erläutert werden. Entwicklungen an dem Modul sollten auf Wikidata utilities/Test und die Anwendung auf der Spielwiese getestet werden, da wiederholte Trial-and-Error-Edits die Resourcen stark belasten können. |
| Dieses Modul benutzt eine oder mehrere Wikidata-Eigenschaften. |
Funktionen zur Vereinfachung des Zugriffs auf Daten aus Wikidata.
Verwendung in anderen Modulen
[Bearbeiten]Dieses Modul ist notwendig für die Ausführung folgender Module. Bei Anpassungen sollte die Funktionstüchtigkeit der folgenden Module geprüft werden. Benutze dazu auch diese Tracking-Kategorie um Fehler zu finden, die sich dann auf Artikel auswirken:
- CountryData • GeoData • Hours • IsIn • Mapframe • Mapshape • Mapshape utilities • Mapshapes • Marker • Marker utilities • Unesco • vCard
- Modul benötigt das Modul Wikidata utilities – Wartungskategorie, in der nochmals alle Module gelistet sind, die von diesem Modul abhängig sind.
Interne Variable
[Bearbeiten]local catTable
- In der Tabelle werden die verwendeten Wikidata-Eigenschaften (Properties) gespeichert.
Funktionen
[Bearbeiten]- Parameter
anEntityWikidata Entity Object (table) oder Wikidata Id (string).idWikidata Id (Q...) string.pWikidata Property (P...) string.countMaximalanzahl der gelieferten Werte. Beicount = nilwerden alle Werte zurückgeliefert.
function wu.getEntity( id )
- liefert
id, entity, wrongQualifier. Prüft eine Qualifier-Id auf Vorhandensein in Wikidata.wrongQualifiernennt mittrueoderfalsedas Ergebnis. Im Erfolgsfall wird zudem einentity-Objekt zurückgeliefert.
function wu.getEntityId( id )
- liefert
id, entity, wrongQualifier. Prüft eine Qualifier-Id auf Vorhandensein in Wikidata.wrongQualifiernennt mittrueoderfalsedas Ergebnis. Im Erfolgsfall wird zudem dieentity-Id zurückgeliefert.
function wu.getLabel( entity, lang, noFallback )
- Liefert das Label der Entity oder Qualifier-Id in der optionalen Sprache
langoder in der Inhaltssprache des Wikis zurück. WennnoFallbackauftruegesetzt wurde, wird das Label ausschließlich in der angegebenen Sprache zurückgegeben.
function wu.getAliases( entity, lang )
- Liefert eine Tabelle mit Aliasen zur Wikidata-Entität
entity. Wenn keine Aliase vorliegen, ist die Tabelle leer. Eine fehlende Sprache wird durch die Sprache des Wikis ersetzt.
function wu.getSitelink( entity, globalSiteId )
- Liefert den Site-Link für das angegebene Wiki
globalSiteId(z. B. enwiki, dewikivoyage).
function wu.getCheckedSitelink( entity, globalSiteId )
- Liefert den Site-Link für das angegebene Wiki
globalSiteId(z. B. enwiki, dewikivoyage) und als zweiten Wert, ob es sich dabei um einen Redirect (true) handelt oder nicht (false).
function wu.getFilteredSitelink( entity, globalSiteId )
- Liefert den Site-Link für das angegebene Wiki
globalSiteId(z. B. enwiki, dewikivoyage), aber nur, wenn dies kein Link zu einem Redirect ist, ansonstennil.
function wu.getValue( entity, p )
- Liefert den ersten Wert als Zeichenkette oder Tabelle, im Fehlerfall eine leere Zeichenkette.
function wu.getId( entity, p )
- Liefert die erste Id als Zeichenkette, im Fehlerfall eine leere Zeichenkette.
function wu.getValues( entity, p, count )
- Liefert maximal die ersten
countWerte als Tabelle zurück, im Fehlerfall die leere Tabelle {}.
function wu.getIds( entity, p, count )
- Liefert maximal die ersten
countIds als Tabelle zurück, im Fehlerfall die leere Tabelle {}.
function wu.getValuesByLang( entity, p, count, lang )
- Liefert maximal die ersten
countWerte als Tabelle zurück, bei denen die Sprachelanggesetzt ist. Im Fehlerfall die leere Tabelle {}. Die Eigenschaftpmuss vom Typ monolingual text sein.
function wu.getMonolingualValues( entity, p )
- Liefert eine Tabelle aller Werte als indizierte Tabelle zurück, im Fehlerfall die leere Tabelle {}. Als Index wird die Sprachbezeichnung benutzt. Es wird der jeweils erste Wert zu einem bestimmten Sprache geliefert.
- Beispiel:
wu.getMonolingualValues( 'Q47429618', 'P6375' )
table#1 {
["ar"] = "٢ شارع قصر النيل ، ميدان التحرير ، القاهرة",
["en"] = "2 Kasr El Nil St., El Tahrir Sq., Cairo",
}
function wu.getValuesByQualifier( entity, p, qualifierP, defaultId )
- Liefert eine Tabelle aller Werte als indizierte Tabelle zurück, im Fehlerfall die leere Tabelle {}.
qualifierPist eine Wikidata Property (P..., string) vom Typ Datenobjekt. Die Datenobjekt-Id stellt den Index in der Tabelle für den zugehörenden Wert dar. Falls keine Datenobjekt-Id gefunden wurde, wird, falls vorhanden,defaultIdbenutzt bzw. der Index 'unknown' benutzt. Es wird der jeweils erste Wert zu einem bestimmten Index geliefert. - Beispiel:
wu.getValuesByQualifier( 'Q47429618', 'P856', 'P407' )
table#1 {
["Q1860"] = "https://www.steigenberger.com/en/hotels/all-hotels/egypt/cairo/steigenberger-el-tahrir-cairo",
["Q188"] = "https://www.steigenberger.com/hotels/alle-hotels/aegypten/kairo/steigenberger-el-tahrir-cairo",
}
function wu.getValuesWithQualifiers( entity, p, values, qualifiers, references, count, labelFct, ... )
- Liefert eine Tabelle, die für jedes Statement eine Tabelle mit dem Wert und den Qualifikatoren enthält.
valuesTabelle gewünschter Werte odernilfür alle.qualifierskannnilfür alle möglichen Qualifikatoren-Eigenschaften, eine Zeichenkete für eine einzelne Qualifikator-Eigenschaft oder eine Tabelle gewünschter Qualifikatoren-Eigenschaften sein. Es werden maximal die erstencountStatements zurückgeliefert.referencesTabelle gewünschter Eigenschaften odernilfür alle.
- Die Funktion
labelFctüberführt einen Qualifier-Id in sein Label....sind zusätzliche Parameter für diese Funktion, die nach der Q-Id an die Funktion übergeben werden. - Beispiel 1:
wu.getValuesWithQualifiers( 'Q183', 'P85' )
table#1 {
table#2 {
["P51"] = table#3 {
"National anthem of Germany - U.S. Army 1st Armored Division Band.ogg",
},
["P51-type"] = "string",
["P805"] = table#4 {
"Q4122341",
},
["P805-type"] = "wikibase-entityid",
["sort1"] = 1,
["sort2"] = 1,
["value"] = "Q44042",
["value-type"] = "wikibase-entityid",
},
}
- Beispiel 2:
wu.getValuesWithQualifiers( 'Q183', 'P85', nil, nil, nil, nil, wu.getLabel, 'en' )
table#1 {
table#2 {
["P51"] = table#3 {
"National anthem of Germany - U.S. Army 1st Armored Division Band.ogg",
},
["P51-type"] = "string",
["P805"] = table#4 {
"National Anthem of Germany",
},
["P805-type"] = "wikibase-entityid",
["sort1"] = 1,
["sort2"] = 1,
["value"] = "Das Lied der Deutschen",
["value-type"] = "wikibase-entityid",
},
}
function wu.getDateFromTime( t )
- Liefert das Datum in der Form YYYY-MM-DD aus einer Zeitangabe zurück. Die Zeitangabe
tmuss mit einem führenden+/-beginnen. Danach folgt die Zeitangabe im ISO-Format. - Beispiel:
wu.getDateFromTime( '+1949-05-29T00:00:00Z' )
1949-05-29
function wu.getLastedit( lastEdit, statements )
- Liefert das aktualisierte Datum der letzten Änderung aus dem Abrufdaten (P813) der Fundstellen.
function wu.getCategories( formatStr )
- Liefert eine Zeichenkette mit den Kategorie-Links aller verwendeten Wikidata-Eigenschaften zurück.