如何使用SPARQL端点通过ID获取维基数据中的英文或任何其他语言的标签?
答案 0 :(得分:9)
假设 wd:Q146190 是 wikidata实体ID
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
PREFIX wd: <http://www.wikidata.org/entity/>
SELECT *
WHERE {
wd:Q146190 rdfs:label ?label .
FILTER (langMatches( lang(?label), "EN" ) )
}
LIMIT 1
SELECT * WHERE {
wd:Q146190 rdfs:label ?label
}
这里the link to the live try按下播放来运行查询然后你可以下载一个完整的JSON并得到这样的重新响应..只是在这里复制了一个主干:
{
"head": {
"vars": [
"label"
]
},
"results": {
"bindings": [
{
"label": {
"xml:lang": "ar",
"type": "literal",
"value": "دوار الشمس الدرني"
}
},
{
"label": {
"xml:lang": "az",
"type": "literal",
"value": "Kökyumrulu günəbaxan"
}
},
..etc,etc.
在这种情况下,您应该使用Label service
SELECT ?p ?pLabel ?w ?wLabel WHERE {
wd:Q30 p:P6/ps:P6 ?p .
?p wdt:P26 ?w .
SERVICE wikibase:label {
bd:serviceParam wikibase:language "en" .
}
}
要使用此服务,请将Label
添加到变量中(例如:?p
标签,您必须使用?pLabel
然后添加
SERVICE wikibase:label {
bd:serviceParam wikibase:language "en" .
}
到WHERE
块