编程语言
首页 > 编程语言> > python – 如何以可读方式从rdflib打印术语文字?

python – 如何以可读方式从rdflib打印术语文字?

作者:互联网

我刚开始使用rdflib并且我有一个程序需要获取一个人的出生日期(在这个例子中,Lewis Carroll).我的程序会这样做,但是当我尝试打印它打印的日期时:
(rdflib.term.Literal(‘1832-01-27’,datatype = rdflib.term.URIRef(‘http://www.w3.org/2001/XMLSchema#date‘)),)

我确信有一种简单的方法来打印日期,但我无法找到如何.
如果它与我的代码有任何相关性:

# open a graph
graph = rdflib.Graph()

# load some data
graph.parse('http://dbpedia.org/resource/Lewis_Carroll')

qres = graph.query(
    ("PREFIX dbpedia: <http://dbpedia.org/resource/>\n"
     "PREFIX dbpedia-owl: <http://dbpedia.org/ontology/>\n"
     "PREFIX foaf: <http://xmlns.com/foaf/0.1/>\n"
     "SELECT ?birth WHERE {\n"
     "        ?person dbpedia-owl:birthDate ?birth . \n"
     "        ?person foaf:givenName ?givenName  . \n"
     "        ?person foaf:surname ?surname . \n"
     "        VALUES ?person { dbpedia:Lewis_Carroll }\n"
     "       }"
     ))

print("the graph has %s statements" % len(qres))

for row in qres:
    print(row)

解决方法:

这是一种从查询中打印日期的方法:

>>> for row in qres:
...     d = str(row.asdict()['birth'].toPython())
...     print(d)
...
1832-01-27
>>>

我解决这个问题的一些线索是http://rdflib.readthedocs.org/en/latest/_modules/rdflib/query.html中记录的rdflib.query.ResultRow.asDict()和http://rdflib.readthedocs.org/en/latest/apidocs/rdflib.html中记录的rdflib.term.Literal.toPython().

请注意,row.asdict()[‘birth’].toPython()是一个datetime.date对象.

标签:python,printing,sparql,dbpedia,rdflib
来源: https://codeday.me/bug/20190623/1273130.html