0

我是 Turtle 格式文件的新手,并使用 SPARQL 查询它们。所以我有很多问题要解决,希望你能帮助我!

我有一个名为 EquipmentCURT3.ttl 的文件,其中包含以下内容:

@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix v: <http://www.w3.org/2006/vcard/ns#> .
@prefix xml: <http://www.w3.org/XML/1998/namespace> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .

<http://opendata.gencat.cat/recursos/equipaments/30883> a v:VCard ;
v:adr [ a v:Work ;
        v:country-name "Spain" ;
        v:locality "Sabadell" ;
        v:postal-code "08202" ;
        v:region "Vallès Occidental" ;
        v:street-address " c.  Sant Josep" ] ;
v:category "2. Parvulari"@ca,
    "3. Educació primària"@ca,
    "4. Educació secundària obligatòria"@ca,
    "Educació. Formació"@ca,
    "Ensenyaments de règim general"@ca ;
v:fn "Escolàpies Sabadell"@ca ;
v:geo [ v:latitude 4.154826e+01 ;
        v:longitude 2.111243e+00 ] ;
v:nickname "Escolàpies Sabadell"@ca ;
v:tel [ a v:Pref,
            v:Tel,
            v:Work ;
        rdf:value "937255348" ] .

<http://opendata.gencat.cat/recursos/equipaments/31264> a v:VCard ;
v:adr [ a v:Work ;
        v:country-name "Spain" ;
        v:locality "Molins de Rei" ;
        v:postal-code "08750" ;
        v:region "Baix Llobregat" ;
        v:street-address " c.  Ntra. Sra. de Lourdes" ] ;
v:category "4. Educació secundària obligatòria"@ca,
    "7. Batxillerat"@ca,
    "8. Cicles formatius d'FP de grau mitjà (CFPM)"@ca,
    "9. Cicles formatius d'FP de grau superior (CFPS)"@ca,
    "Educació. Formació"@ca,
    "Ensenyaments de règim general"@ca ;
v:fn "Institut Bernat el Ferrer"@ca ;
v:geo [ v:latitude 4.14105e+01 ;
        v:longitude 2.02704e+00 ] ;
v:nickname "Institut Bernat el Ferrer"@ca ;
v:tel [ a v:Pref,
            v:Tel,
            v:Work ;
        rdf:value "936683762" ] .

<http://opendata.gencat.cat/recursos/equipaments/31265> a v:VCard ;
v:adr [ a v:Work ;
        v:country-name "Spain" ;
        v:locality "Castellar del Vallès" ;
        v:postal-code "08211" ;
        v:region "Vallès Occidental" ;
        v:street-address " NC  Bonavista" ] ;
v:category "2. Parvulari"@ca,
    "3. Educació primària"@ca,
    "Educació. Formació"@ca,
    "Ensenyaments de règim general"@ca ;
v:fn "Escola Bonavista"@ca ;
v:geo [ v:latitude 4.161903e+01 ;
        v:longitude 2.091745e+00 ] ;
v:nickname "Escola Bonavista"@ca ;
v:tel [ a v:Pref,
            v:Tel,
            v:Work ;
        rdf:value "937144195" ] .

我正在使用 Python3.5 和一个名为 RDFLib ( https://github.com/RDFLib/rdflib ) 的库。我需要从一个名为 equipmentCURT.rdf 的文件中读取数据,将其序列化为 equipmentCURT3.ttl,然后检索与设备相关的所有信息。例如,对于设备 30883 ( http://opendata.gencat.cat/recursos/equipaments/30883 ),我想要v:adr,v:category,v:fn,v:geo 和 v:tel。为了获取这些数据,我使用了 SPARQL,但我不知道为什么查询不起作用。我对如何查询信息感到非常困惑。

这是我的代码:

import rdflib , pprint
from rdflib import URIRef, Graph
from rdflib.plugins import sparql

g = Graph()
g.load("equipamentsCURT3.ttl", format='turtle')

queryTest = 'prefix v: <http://www.w3.org/2006/vcard/ns#> ' \
'select ?y where {?x  a <http://opendata.gencat.cat/recursos/equipaments 30883>; ?y v:VCard .}'
qresult = g.query(queryTest)

for st in qresult:
 print rdflib.term.Literal(st).value
4

1 回答 1

1

整个查询没有任何意义,也不匹配数据。我建议先阅读 SPARQL 教程。整个查询看起来像是从其他东西复制粘贴 + 一些随机的东西从你身边。

  1. URIhttp://opendata.gencat.cat/recursos/equipaments 30883包含一个错误的空格

  2. http://opendata.gencat.cat/recursos/equipaments/30883不是一个类。因此,三元组模式 ?x a <http://opendata.gencat.cat/recursos/equipaments/30883>,这意味着属于该类的所有资源http://opendata.gencat.cat/recursos/equipaments/30883都与您的数据不匹配。

  3. 第二个三重模式是?x ?y v:VCard。并且您选择谓词?y作为查询的最终结果。但是您想要给定主题和一组给定谓词的对象。三元组/resp的语法。三重模式)是主谓宾。因此,例如v:category它应该是

PREFIX v: <http://www.w3.org/2006/vcard/ns#> 
SELECT ?o WHERE {
  <http://opendata.gencat.cat/recursos/equipaments/30883>  v:category ?o 
}

对于其他属性,它会更加复杂,因为值本身是通过附加属性附加了多个值的空白节点。例如,v:adr它会是

PREFIX v: <http://www.w3.org/2006/vcard/ns#> 
SELECT ?p ?o WHERE {
  <http://opendata.gencat.cat/recursos/equipaments/30883>  v:adr ?adr .
  ?adr ?p ?o 
}

更新

如果您不想要这些值而是属性,那么将变量放在谓词位置是正确的。但是将其限制为仅与对象三元组出现的那些属性是错误的,v:VCard因为除此之外没有这样的属性rdf:typea只是它的同义词)。在这种情况下,它应该是

PREFIX v: <http://www.w3.org/2006/vcard/ns#> 
SELECT DISTINCT ?p WHERE {
  <http://opendata.gencat.cat/recursos/equipaments/30883>  ?p ?o 
}
于 2017-03-04T19:26:34.687 回答