问题描述
我正在尝试在此处完成教程: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 (将#修改为@)