问题描述
我正在尝试获取每个国家/地区维基百科上所有足球运动员的出生日期。到目前为止,我已经设法获得了一个国家/地区的所有数据,但我想同时获得多个国家/地区的数据,例如:
SELECT ?person ?dateOfBirth
WHERE {
?person wdt:P1532 wd:Q16 OR ?person wdt:P1532 wd:Q141;
wdt:P569 ?dateOfBirth.
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
}
Q16 是加拿大,Q141 是阿根廷
谢谢!
解决方法
为了不将您的查询限制在单个国家/地区,请将 wd:Q16
替换为变量,即 ?person wdt:P1531 ?country
。
然后您需要将查询限制为足球运动员。 这可以通过以下行来完成
?person wdt:P106 wd:Q937857.
而且您可能想要玩家的名字,而不仅仅是 der ID。因此,在“选择”之后添加 ?personLabel
。
组合,查询读取
SELECT ?person ?personLabel ?country ?countryLabel ?dateOfBirth
WHERE {
?person wdt:P106 wd:Q937857;
wdt:P1532 ?country;
wdt:P569 ?dateOfBirth.
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
}