将元组列表更改为字典(pythonic方式)

时间:2014-07-16 13:12:18

标签: python list sqlite dictionary tuples

这是一个最佳实践问题。我所创造的是完美的工作,但我很好奇是否有一种较短的方法可以从我当前的数据结构中创建字典。

我正在从SQLite数据库中读取表格,数据作为元组列表返回。 例如

[(49, u'mRec49', u'mLabel49', 1053, 1405406806822606L, u'1405406906822606'), 
(48, u'mRec48', u'mLabel48', 1330, 1405405806822606L, u'1405405906822606'), 
(47, u'mRec47', u'mLabel47', 1220, 1405404806822606L, u'1405404906822606')...
] 

我想获取list-tuple结构的每一列,使其成为一个列表,从数据库中获取列名,并将其用作保存列表的键。后来我将字典变为JSON。

这是我的功能,我抓了它,它完成了工作,我不禁想知道是否有更好的方法来做到这一点。

def make_dict(columns, list_o_tuples):
    anary = {}
    for j, column in enumerate(columns):
        place = []
        for row in list_o_tuples:
            place.append(row[j])
        anary[column] = place
    return anary

make_dict(mDBTable.columns, mDBTable.get_table())

注意:该功能不应该关心它所呈现的表格,或者数字或行数&表中的列。

2 个答案:

答案 0 :(得分:6)

您似乎想要转置list_o_tuples:

transpose = zip(*list_o_tuples)

然后用列名称将其压缩:

return dict(zip(columns, transpose))

答案 1 :(得分:2)

您只需解压缩list_o_tuples,然后使用字典理解创建一个包含相应列数据和列标题的新字典

columns = ["num1", "str1", "num2", "num3", "str2", "str3"]
print {columns[idx]:row for idx, row in enumerate(zip(*list_o_tuples))}