3

我正在尝试解析来自 Sesame 的 SPARQL 查询的结果。我找到了示例代码,下面的相关部分,我在下面显示了我的结果。

(response, content) = httplib2.Http().request(endpoint, 'POST', urllib.urlencode(params), headers=headers)

print "Response %s" % response.status
results = json.loads(content)
print "\n".join([result['type']['value'] for result in results['results']['bindings']])

{

   "head": {

       "vars": [ "costar", "movie" ]

   },

   "results": {

       "bindings": [

           {

               "costar": { "type": "uri", "value": "http:\/\/rdf.freebase.com\/ns\/en.connie_nielsen" },

               "movie": { "type": "uri", "value": "http:\/\/rdf.freebase.com\/ns\/en.basic_2003" }

           },

           {

               "costar": { "type": "uri", "value": "http:\/\/rdf.freebase.com\/ns\/en.timothy_daly" },

               "movie": { "type": "uri", "value": "http:\/\/rdf.freebase.com\/ns\/en.basic_2003" }

           },


      ]

   }

}     

但我得到这个错误:

Traceback (most recent call last):
  File "C:\Software\rdflib\movieSparqlQuery.py", line 45, in <module>
    print "\n".join([result['type']['value'] for result in results['results']['b
indings']])
KeyError: 'type'
Press any key to continue . . .

如何更改“打印”语句?

我想看到的是同一行中的 costar 和电影名称:

http://rdf.freebase.com/ns/en.connie_nielsen  http://rdf.freebase.com/ns/en.basic_2003

稍后,我将剥离命名空间。

谢谢!

4

2 回答 2

2

您收到的错误表明result字典没有 key 'type'。如果您仔细检查, 的每个元素results['results']['bindings']都是具有两个键的字典:'costar''movie',因此您的result变量将是具有这两个键的字典。

每个result['costar']result['movie']也是具有两个键的字典:'type''value'。您真正想要的是构建一个包含空格result['costar']['value']result['movie']['value']用空格分隔的字符串。给定一个result,您可以通过以下方式实现:

" ".join(result[var]['value'] for var in results['head']['vars'])

现在要打印一个包含由换行符分隔的所有 costars 和电影的字符串,您只需将 print 语句修改为

print "\n".join([" ".join(result[var]['value'] for var in results['head']['vars']) for result in results['results']['bindings']])
于 2011-05-09T01:29:39.197 回答
0

查看SPARQLWrapper的示例代码:

for result in results["results"]["bindings"]:
    print(result["label"]["value"])
于 2012-05-22T18:22:11.560 回答