Use Jena to query wikidata(使用Jena查询Wikidata)
问题描述
目前,Wikidata有一个SPARQL终结点"https://query.wikidata.org/",我想使用Jena(3.0.1)查询此站点,我使用了以下代码,但我收到错误消息"终结点返回Content-Type:Text/html,这当前不支持SELECT查询"。有没有办法解决这个问题?相同的代码在DBpedia上运行得很好。谢谢
java">queryString = "PREFIX bd: <http://www.bigdata.com/rdf#>
" +
"PREFIX wikibase: <http://wikiba.se/ontology#>
" +
"PREFIX wdt: <http://www.wikidata.org/prop/direct/>
" +
"PREFIX wd: <http://www.wikidata.org/entity/>
" +
"SELECT DISTINCT ?country ?countryLabel
" +
"WHERE
" +
"{
" +
" ?country wdt:P31 wd:Q3624078 .
" +
" ?country wdt:P1622 wd:Q13196750.
" +
" ?country wdt:P30 wd:Q15
" +
" FILTER NOT EXISTS {?country wdt:P31 wd:Q3024240}
" +
" SERVICE wikibase:label { bd:serviceParam wikibase:language "en" }
" +
"}
" +
"ORDER BY ?countryLabel";
query = QueryFactory.create(queryString);
qexec = QueryExecutionFactory.sparqlService("https://query.wikidata.org/", queryString);
try {
ResultSet results = qexec.execSelect();
ResultSetFormatter.out(System.out, results, query);
} catch (Exception ex) {
System.out.println(ex.getMessage());
} finally {
qexec.close();
}
推荐答案
根据the documentation,终结点的末尾有一个/SPARQL。上面写着
SPARQL查询可以通过对
https://query.wikidata.org/sparql?query={SPARQL}
的GET请求直接提交到SPARQL端点(POST和其他方法请求将被拒绝,并带有"403禁止")。默认情况下,结果以XML形式返回,如果提供了查询参数Format=json或头文件Accept:Application/SPARQL-Results+json,则以JSON形式返回。
这篇关于使用Jena查询Wikidata的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用Jena查询Wikidata


基础教程推荐
- Struts2 URL 无法访问 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01