如何解决如何防止在来自 Neo4j 的 Wikidata 查询中进行不必要的编码?
我正在尝试在此处完成教程:https://www.markhneedham.com/blog/2020/02/04/neo4j-enriching-existing-graph-wikidata-sparql-api/
但是,当我到达产生表 3 结果的 Cypher 查询时:
MATCH (player:Player)
WHERE player.name = "Nick Kyrgios"
WITH "SELECT *
WHERE { ?person wdt:P106 wd:Q10833314 ;
rdfs:label \"" + player.name + "\"@en ;
wdt:P569 ?dateOfBirth ;
wdt:P27 [ rdfs:label ?countryName ] .
filter(lang(?countryName) = \"en\")
}" AS sparql
CALL apoc.load.jsonParams(
"https://query.wikidata.org/sparql?query=" + apoc.text.urlencode(sparql),{ Accept: "application/sparql-results+json"},null
)
YIELD value
RETURN value
我收到以下错误:
无法调用过程 apoc.load.jsonParams
:导致:java.lang.RuntimeException:无法将 url 或键 https://query.wikidata.org/sparql?query=SELECT+*%250AWHERE+%257B+%253Fperson+wdt%253AP106+wd%253AQ10833314+%253B%250A++++++++++++++++rdfs%253Alabel+%2522Nick+Kyrgios%2522%2540en+%253B%250A++++++++++++++++wdt%253AP569+%253FdateOfBirth+%253B%250A++++++++++++++++wdt%253AP27+%255B+rdfs%253Alabel+%253FcountryName+%255D+.%250A+++++++filter%2528lang%2528%253FcountryName%2529+%253D+%2522en%2522%2529%250A%257D 读取为 json:服务器返回 HTTP 响应代码:400 用于 URL:{{3 }}
当我在 Wikidata 的沙箱上单独运行 Sparql 查询时,我没有收到任何错误。我认为问题与编码有关(错误消息中的 URL 有额外的“25”,大概是因为它对所有 % 符号进行了双重编码)。当我从错误消息中复制/粘贴 URL 并手动删除所有 25 个 URL 时,它连接到 Wikidata 并返回一个 JSON 文件就好了。
我已经尝试过 Cypher 的 REPLACE() 函数来消除额外的 25 个,但它并没有消除它们,我最终得到了相同的错误消息。
有没有人遇到过这个问题并找到了解决方法?
Ubuntu 20.04,Neo4j Desktop 1.4.5,我安装了 APOC 插件
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。