gpt4 book ai didi

java - 使用 Java 代码查询 SPARQL 到 DBPedia

转载 作者:搜寻专家 更新时间:2023-11-01 04:04:17 24 4
gpt4 key购买 nike

我想获取 DBPedia 上标签等于 "London" 的页面的 URI。也就是说,当我查询 DBPedia 时,如果页面属性 rdfs:label 的值为 "London",那么我想获取它的 URI,例如 http://dbpedia.org/resource/London .我正在使用以下 Java 代码,但没有得到任何结果。我在这里做错了什么?

String strings = "London";
String service = "http://dbpedia.org/sparql";
String query = "PREFIX dbo:<http://dbpedia.org/ontology/>"
+ "PREFIX : <http://dbpedia.org/resource/>"
+ "PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#/>"
+ "select ?URI where {?URI rdfs:label "+strings+".}";
QueryExecution qe=QueryExecutionFactory.sparqlService(service, query);
ResultSet rs = qe.execSelect();
while (rs.hasNext()){
QuerySolution s= rs.nextSolution();
System.out.println(s.getResource("?URI").toString());
}

最佳答案

如果你对 DBpedia endpoint 进行这样的查询,你会得到一个解析错误:

select ?resource where {
?resource rdfs:label London
}
Virtuoso 37000 Error SP030: SPARQL compiler, line 4: syntax error at 'London' before '}'

SPARQL query:
define sql:big-data-const 0
#output-format:text/html
define sql:signal-void-variables 1 define input:default-graph-uri <http://dbpedia.org> select ?resource where {
?resource rdfs:label London
}

您需要将字符串放在单引号或双引号内。所以你有一个像这样的查询,它解析正确,但仍然没有结果:

select ?resource where {
?resource rdfs:label "London"
}

SPARQL results

很多时候,当您使用 DBpedia 时,手动浏览数据以找出其中的内容,然后根据这些知识进行查询会大有帮助。在这种情况下,您对 http://dbpedia.org/page/London 感兴趣。如果你把它放在网络浏览器中,你会看到伦敦的一堆信息。如果滚动到底部,您可以单击 N3/Turtle 以查看 Turtle 序列化中的相同信息,这与 SPARQL 语法非常接近。如果您在该页面中搜索 rdfs:label,您将看到:

dbpedia:London  rdfs:label  "Londres"@fr ,
"London"@en ,
"London"@sv ,
"Londra"@it ,
"\u30ED\u30F3\u30C9\u30F3"@ja ,
"\u4F26\u6566"@zh ,
"Londres"@es ,
"Londyn"@pl ,
"Londen"@nl ,
"Londres"@pt ,
"\u041B\u043E\u043D\u0434\u043E\u043D"@ru ,
"London"@de ;

DBpedia 中的大多数(也许是全部)标签都有语言标签,因此您实际上需要搜索标签为"London"@en 的内容。例如,您可以使用此查询来获取这些结果:

select ?resource where {
?resource rdfs:label "London"@en
}

SPARQL results

您的大部分查询代码都是正确的,但您只需要对文字使用正确的语法,并且需要知道 DBpedia 中的数据是什么样的。这也是参数化 SPARQL 字符串的一个很好的例子。 get latitude and longitude of a place dbpedia 中有一个示例,但简短的想法是您应该能够编写

select ?resource where {
?resource rdfs:label ?label
}

作为 ParmeterizedSparqlString,然后使用 API 方法将 ?label 替换为您想要的文字(在本例中为 "London"@en),而无需做任何字符串连接。 ParameterizedSparqlString 还将确保所有引用都正确完成,并且文字以正确的方式格式化。这是一个例子:

import com.hp.hpl.jena.query.ParameterizedSparqlString;
import com.hp.hpl.jena.query.QueryExecution;
import com.hp.hpl.jena.query.QueryExecutionFactory;
import com.hp.hpl.jena.query.ResultSet;
import com.hp.hpl.jena.query.ResultSetFactory;
import com.hp.hpl.jena.query.ResultSetFormatter;
import com.hp.hpl.jena.rdf.model.Literal;
import com.hp.hpl.jena.rdf.model.ResourceFactory;

public class LondonExample {
public static void main(String[] args) {
ParameterizedSparqlString qs = new ParameterizedSparqlString( "" +
"prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>\n" +
"\n" +
"select ?resource where {\n" +
" ?resource rdfs:label ?label\n" +
"}" );

Literal london = ResourceFactory.createLangLiteral( "London", "en" );
qs.setParam( "label", london );

System.out.println( qs );

QueryExecution exec = QueryExecutionFactory.sparqlService( "http://dbpedia.org/sparql", qs.asQuery() );

// Normally you'd just do results = exec.execSelect(), but I want to
// use this ResultSet twice, so I'm making a copy of it.
ResultSet results = ResultSetFactory.copyResults( exec.execSelect() );

while ( results.hasNext() ) {
// As RobV pointed out, don't use the `?` in the variable
// name here. Use *just* the name of the variable.
System.out.println( results.next().get( "resource" ));
}

// A simpler way of printing the results.
ResultSetFormatter.out( results );
}
}
prefix rdfs:    <http://www.w3.org/2000/01/rdf-schema#>

select ?resource where {
?resource rdfs:label "London"@en
}
http://dbpedia.org/resource/London
http://dbpedia.org/resource/Category:London
http://www.ontologyportal.org/SUMO#LondonUnitedKingdom
http://sw.opencyc.org/2008/06/10/concept/en/London
http://sw.opencyc.org/2008/06/10/concept/Mx8Ngx4rvWhwppwpEbGdrcN5Y29ycA-GTG9uZG9uHiu9WLbVnCkRsZ2tw3ljb3Jw
http://wikidata.dbpedia.org/resource/Q1442133
http://wikidata.dbpedia.org/resource/Q261303
http://wikidata.dbpedia.org/resource/Q79348
http://wikidata.dbpedia.org/resource/Q92561
http://wikidata.dbpedia.org/resource/Q3258936
http://wikidata.dbpedia.org/resource/Q84
http://wikidata.dbpedia.org/resource/Q6669759
http://wikidata.dbpedia.org/resource/Q6669762
http://wikidata.dbpedia.org/resource/Q6669763
http://wikidata.dbpedia.org/resource/Q6669771
http://wikidata.dbpedia.org/resource/Q586353
http://wikidata.dbpedia.org/resource/Q1310705
http://wikidata.dbpedia.org/resource/Q1749384
http://wikidata.dbpedia.org/resource/Q3836562
http://wikidata.dbpedia.org/resource/Q3836563
http://wikidata.dbpedia.org/resource/Q3836565
http://wikidata.dbpedia.org/resource/Q1001456
http://wikidata.dbpedia.org/resource/Q5712562
http://wikidata.dbpedia.org/resource/Q3061911
http://wikidata.dbpedia.org/resource/Q6669774
http://wikidata.dbpedia.org/resource/Q6669754
http://wikidata.dbpedia.org/resource/Q6669757
http://wikidata.dbpedia.org/resource/Q6669761
http://wikidata.dbpedia.org/resource/Q6669767
http://wikidata.dbpedia.org/resource/Q6669769
http://wikidata.dbpedia.org/resource/Q2477346
---------------------------------------------------------------------------------------------------------------
| resource |
===============================================================================================================
| <http://dbpedia.org/resource/London> |
| <http://dbpedia.org/resource/Category:London> |
| <http://www.ontologyportal.org/SUMO#LondonUnitedKingdom> |
| <http://sw.opencyc.org/2008/06/10/concept/en/London> |
| <http://sw.opencyc.org/2008/06/10/concept/Mx8Ngx4rvWhwppwpEbGdrcN5Y29ycA-GTG9uZG9uHiu9WLbVnCkRsZ2tw3ljb3Jw> |
| <http://wikidata.dbpedia.org/resource/Q1442133> |
| <http://wikidata.dbpedia.org/resource/Q261303> |
| <http://wikidata.dbpedia.org/resource/Q79348> |
| <http://wikidata.dbpedia.org/resource/Q92561> |
| <http://wikidata.dbpedia.org/resource/Q3258936> |
| <http://wikidata.dbpedia.org/resource/Q84> |
| <http://wikidata.dbpedia.org/resource/Q6669759> |
| <http://wikidata.dbpedia.org/resource/Q6669762> |
| <http://wikidata.dbpedia.org/resource/Q6669763> |
| <http://wikidata.dbpedia.org/resource/Q6669771> |
| <http://wikidata.dbpedia.org/resource/Q586353> |
| <http://wikidata.dbpedia.org/resource/Q1310705> |
| <http://wikidata.dbpedia.org/resource/Q1749384> |
| <http://wikidata.dbpedia.org/resource/Q3836562> |
| <http://wikidata.dbpedia.org/resource/Q3836563> |
| <http://wikidata.dbpedia.org/resource/Q3836565> |
| <http://wikidata.dbpedia.org/resource/Q1001456> |
| <http://wikidata.dbpedia.org/resource/Q5712562> |
| <http://wikidata.dbpedia.org/resource/Q3061911> |
| <http://wikidata.dbpedia.org/resource/Q6669774> |
| <http://wikidata.dbpedia.org/resource/Q6669754> |
| <http://wikidata.dbpedia.org/resource/Q6669757> |
| <http://wikidata.dbpedia.org/resource/Q6669761> |
| <http://wikidata.dbpedia.org/resource/Q6669767> |
| <http://wikidata.dbpedia.org/resource/Q6669769> |
| <http://wikidata.dbpedia.org/resource/Q2477346> |
---------------------------------------------------------------------------------------------------------------

关于java - 使用 Java 代码查询 SPARQL 到 DBPedia,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24116853/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com