首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否有使用RDFLib的SPARQL的Hello示例?

是否有使用RDFLib的SPARQL的Hello示例?
EN

Stack Overflow用户
提问于 2013-05-30 06:27:18
回答 1查看 7.6K关注 0票数 6

我想得到尽可能小,但仍然是自洽和工作的例子,使用SPARQL从RDFLib。我有RDFLib版本的4.0.1。

我希望有一个代码来执行以下操作

  1. 导入RDFLib。
  2. 创建一个简单的图(从2到4个关系)
  3. 将此图写入rdf格式的文件中。
  4. 从文件中读取图形。
  5. 使用SPARQL从图表中提取一些内容。

添加了

我自己尝试过(第一次不写文件,也不读文件),但我做不到。这就是我所拥有的:

代码语言:javascript
复制
import rdflib

g = rdflib.ConjunctiveGraph()

has_border_with = rdflib.URIRef('www.example.org/has_border_with')
located_in = rdflib.URIRef('www.example.org/located_in')

germany = rdflib.URIRef('www.example.org/country1')
france = rdflib.URIRef('www.example.org/country2')
china = rdflib.URIRef('www.example.org/country3')
mongolia = rdflib.URIRef('www.example.org/country4')

europa = rdflib.URIRef('www.example.org/part1')
asia = rdflib.URIRef('www.example.org/part2')

g.add((germany,has_border_with,france))
g.add((china,has_border_with,mongolia))
g.add((germany,located_in,europa))
g.add((france,located_in,europa))
g.add((china,located_in,asia))
g.add((mongolia,located_in,asia))

x = g.query("""select ?country where { ?country www.example.org/located_in www.example.org/part1 }""")
print x

因此,我得到:

代码语言:javascript
复制
Traceback (most recent call last):
  File "hello_world.py", line 23, in <module>
    x = g.query("""select ?country where { ?country www.example.org/located_in www.example.org/part1 }""")
  File "/usr/local/lib/python2.7/dist-packages/rdflib-4.0.1-py2.7.egg/rdflib/graph.py", line 1045, in query
    query_object, initBindings, initNs, **kwargs))
  File "/usr/local/lib/python2.7/dist-packages/rdflib-4.0.1-py2.7.egg/rdflib/plugins/sparql/processor.py", line 72, in query
    parsetree = parseQuery(strOrQuery)
  File "/usr/local/lib/python2.7/dist-packages/rdflib-4.0.1-py2.7.egg/rdflib/plugins/sparql/parser.py", line 1034, in parseQuery
    return Query.parseString(q, parseAll=True)
  File "/usr/lib/python2.7/dist-packages/pyparsing.py", line 1032, in parseString
    raise exc
pyparsing.ParseException: Expected "}" (at char 24), (line:1, col:25)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-30 22:02:53

有几个问题:

  1. http://开始命名资源
  2. SPARQL查询中的URL需要周围的<>
  3. 使用简单的Graph而不是ConjunctiveGraph
  4. 您可以使用Graph.serializeGraph.parse方法保存和读取文件(请参阅代码)

尝试对示例代码进行以下修改:

代码语言:javascript
复制
import rdflib

g = rdflib.Graph()
has_border_with = rdflib.URIRef('http://www.example.org/has_border_with')
located_in = rdflib.URIRef('http://www.example.org/located_in')

germany = rdflib.URIRef('http://www.example.org/country1')
france = rdflib.URIRef('http://www.example.org/country2')
china = rdflib.URIRef('http://www.example.org/country3')
mongolia = rdflib.URIRef('http://www.example.org/country4')

europa = rdflib.URIRef('http://www.example.org/part1')
asia = rdflib.URIRef('http://www.example.org/part2')

g.add((germany,has_border_with,france))
g.add((china,has_border_with,mongolia))
g.add((germany,located_in,europa))
g.add((france,located_in,europa))
g.add((china,located_in,asia))
g.add((mongolia,located_in,asia))

q = "select ?country where { ?country <http://www.example.org/located_in> <http://www.example.org/part1> }"
x = g.query(q)
print list(x)
# write graph to file, re-read it and query the newly created graph
g.serialize("graph.rdf")
g1 = rdflib.Graph()
g1.parse("graph.rdf", format="xml")
x1 = g1.query(q)
print list(x1)
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16829351

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档