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