sparql - 如何使用 SPARQL 查询 wikidata 以找到符合特定条件且地理位置靠近另一个城市的地点
问题描述
我编写了以下 SPARQL 查询以在意大利查找带有“San Leucio”标签的 wikidata 项目。
SELECT DISTINCT * WHERE {
?location ?label 'San Leucio'@en .
?location wdt:P17 wd:Q38 .
?location rdfs:label ?locationName .
OPTIONAL {
?article schema:about ?location .
?article schema:isPartOf <https://en.wikivoyage.org/> .
}
?location wdt:P18 ?image .
FILTER(lang(?locationName) = "en")
}
查询返回以下 3 个结果:
wd:Q55179410
wd:Q20009063
wd:Q846499
我想要的结果是wd:Q846499,它位于意大利那不勒斯之外。有什么方法可以进一步过滤此查询以返回最接近那不勒斯的结果?我知道我可以使用 获取其中每一个?location wdt:P625 ?coordinates
的地理坐标,但我不确定如何使用它与那不勒斯的地理坐标进行比较以获得我想要的。
解决方案
SELECT DISTINCT * {
VALUES ?naples {wd:Q2634}
?Napfes wdt:P625 ?naples_coordinates.
?location rdfs:label 'San Leucio'@en .
?location wdt:P17 wd:Q38 .
?location wdt:P18 ?image .
?location wdt:P625 ?location_coordinates.
OPTIONAL {
?article schema:about ?location .
?article schema:isPartOf <https://en.wikivoyage.org/> .
}
BIND (geof:distance(?location_coordinates, ?naples_coordinates) AS ?distance)
} ORDER BY ?distance LIMIT 1
推荐阅读
- html - 如何将img放在div旁边?
- reactjs - 如何使用 React js 中的 Hooks 在网页上上传/浏览和显示图像?
- php - 执行功能不起作用它在窗口数组问题中出错
- java - 从 URL 获取 Json 中的多个 UUID
- c - 我无法连接 ATtiny85 和 EM18(RFID 阅读器)
- spring - 想按类型查找用户
- java - 在 Manjaro Linux 上运行 Java 程序
- python - 使用python在Excel中搜索字符串
- html - MediaQuery 不工作。对于桌面(超过 992 像素)全部保留在一行中,对于平板电脑,前 2 个应为 50% 宽度,第 3 个应为 100%,对于移动设备全部为 100%
- perl - 为什么这个 Perl 的斐波那契单线行得通?