如何使用SPARQL端点通过ID在维基数据中获得英语或任何其他语言的标签?
假设wd:Q146190是您的维基数据实体ID
获取您的特定实体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
英文实例
德文实例
获取您的特定实体ID的任何语言的所有标签:
SELECT * WHERE {
wd:Q146190 rdfs:label ?label
}
这里的链接到现场尝试按播放运行查询,然后你可以下载一个完整的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.
为具有多个ID的响应结果集中的每个实体ID获取标签
在本例中,您应该使用Label服务
不带标签的示例
示例,以指定的语言为每个实体提供标签:english
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
块