我使用Protege生成了一个owl文件。现在,我希望从中访问类 RailwayStation 的所有实例的所有 stationCode 属性值。
我的OWL文件包含以下格式
<?xml version="1.0"?>
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:swrlb="http://www.w3.org/2003/11/swrlb#"
xmlns:xsp="http://www.owl-ontologies.com/2005/08/07/xsp.owl#"
xmlns:owl="http://www.w3.org/2002/07/owl#"
xmlns:protege="http://protege.stanford.edu/plugins/owl/protege#"
xmlns:swrl="http://www.w3.org/2003/11/swrl#"
xmlns:swrla="http://swrl.stanford.edu/ontologies/3.3/swrla.owl#"
xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
xmlns:sqwrl="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl#"
xmlns="http://www.owl-ontologies.com/RailwaysSemantic.owl#"
xmlns:xsd="http://www.w3.org/2001/XMLSchema#"
xml:base="http://www.owl-ontologies.com/RailwaysSemantic.owl">
<owl:Ontology rdf:about="">
<owl:imports rdf:resource="http://swrl.stanford.edu/ontologies/3.3/swrla.owl"/>
<owl:imports rdf:resource="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl"/>
</owl:Ontology>
<rdfs:Class rdf:ID="BusStand"/>
<rdfs:Class rdf:ID="Eatery"/>
<rdfs:Class rdf:ID="Train"/>
<rdfs:Class rdf:ID="Hospital"/>
<rdfs:Class rdf:ID="City"/>
<rdfs:Class rdf:ID="RailwayStation"/>
<rdfs:Class rdf:ID="Airport"/>
<rdfs:Class rdf:ID="TouristSpot"/>
<rdfs:Class rdf:ID="Schedule"/>
<RailwayStation rdf:ID="RailwayStation_YPR">
<stationCode rdf:datatype="http://www.w3.org/2001/XMLSchema#string">
YPR</stationCode>
</RailwayStation>
如何为此目的编写SPARQL查询?
我目前的疑问是:
String querystr = "PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>"+
"PREFIX owl:<http://www.w3.org/2002/07/owl#>"+
"PREFIX rdfs:<http://www.w3.org/2000/01/rdf-schema#>"+
"SELECT * WHERE {"+
"?RailwayStation stationCode ?x ."+
"}";
但它给出了这样的例外:
Exception in thread "main" com.hp.hpl.jena.query.QueryParseException: Lexical error at line 1, column 194. Encountered: " " (32), after : "stationCode"
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.perform(ParserSPARQL11.java:111)
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.parse$(ParserSPARQL11.java:53)
at com.hp.hpl.jena.sparql.lang.SPARQLParser.parse(SPARQLParser.java:37)
at com.hp.hpl.jena.query.QueryFactory.parse(QueryFactory.java:148)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:80)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:53)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:41)
at org.iiitb.jena.Main.sprqltest(Main.java:70)
at org.iiitb.jena.Main.main(Main.java:22)
答案 0 :(得分:2)
&#34;?RailwayStation stationCode?x。&#34;
该属性必须是URI(具有&lt;&gt;)或带前缀的名称(带冒号)。
答案 1 :(得分:2)
您的文件和查询存在一些问题。首先,您必须知道在xml / rdf文件中声明base
命名空间时,所有没有特定命名空间的标记都将添加到基本命名空间http://www.owl-ontologies.com/RailwaysSemantic.owl
中。但在你的情况下,我认为Protege会为你创建这个命名空间。关于您的文件,将# or /
添加到基本命名空间的末尾。
最后,对于您的查询:添加前缀PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
,就像您对rdf和rdfs一样......
在此之后,您希望访问IronStation类的所有实例的所有stationCode属性值,回答这个问题的sparql查询是:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s a <http://www.owl-ontologies.com/RailwaysSemantic.owl#RailwayStation> .
?s <http://www.owl-ontologies.com/RailwaysSemantic.owl#stationCode> ?o}
我在你的文件中测试了它,它返回了良好的结果。我故意不在我的查询中使用命名空间,因此您可以立即在数据中测试它而无需更改命名空间;) 祝你好运
答案 2 :(得分:1)
我们可以通过使用前缀使其更具可读性,如下所示:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s base:RailwayStation .
?s base:stationCode ?o}