微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何防止在来自 Neo4j 的 Wikidata 查询中进行不必要的编码?

如何解决如何防止在来自 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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?