python字典遍历中的逻辑错误

2024-04-30 06:59:00 发布

您现在位置:Python中文网/ 问答频道 /正文

我通过pymongo在mongoDB中的一个查询返回:

{ "_id" : { "origin" : "ABE", "destination" : "DTW", "carrier" : "EV" }, "Ddelay" : -5.333333333333333,
 "Adelay" : -12.666666666666666 }
{ "_id" : { "origin" : "ABE", "destination" : "ORD", "carrier" : "EV" }, "Ddelay" : -4, "Adelay" : 14 }

{ "_id" : { "origin" : "ABE", "destination" : "ATL", "carrier" : "EV" }, "Ddelay" : 6, "Adelay" : 14 }

我在python模块中遍历下面的结果,但是我没有得到所有3个结果,只有两个。我相信我不应该像现在这样使用len(results)。你能帮我正确遍历结果吗,因为我需要在webui上的json文档中显示所有三个结果。 谢谢你

代码:

pipe = [{ '$match': { 'origin': {"$in" : [origin_ID]}}},
             {"$group" :{'_id': { 'origin':"$origin", 'destination': "$dest",'carrier':"$carrier"},
             "Ddelay" : {'$avg' :"$dep_delay"},"Adelay" : {'$avg' :"$arr_delay"}}}, {"$limit" : 4}]
    results = connect.aggregate(pipeline=pipe)
    #pdb.set_trace()
    DATETIME_FORMAT = '%Y-%m-%d'
    for x in range(len(results)):
        origin = (results['result'][x])['_id']['origin']
        destination = (results['result'][x])['_id']['destination']
        carrier = (results['result'][x])['_id']['carrier']
        Adelay = (results['result'][x])['Adelay'] 
        Ddelay = (results['result'][x])['Ddelay']        
        obj = {'Origin':origin,
                'Destination':destination,
                'Carrier': carrier,
                'Avg Arrival Delay': Adelay,
                'Avg Dep Delay': Ddelay}
        json_result.append(obj)
    return json.dumps(json_result,indent= 2, sort_keys=False,separators=(',',':'))

Tags: inidjsonlenoriginresultdestinationresults
1条回答
网友
1楼 · 发布于 2024-04-30 06:59:00

Pymango以以下格式返回结果:

{u'ok': 1.0, u'result': [...]}

所以你应该迭代结果:

for x in results['result']:
    ...

在代码中,您试图计算dict的长度,而不是结果容器的长度

相关问题 更多 >