Python 多重列表解析里for的顺序

2014-05-01
本文发布至今已有8年零222天,可能不再适用,请谨慎对待。

目标

比如有一个二维数组字典,我们如果想将它拉伸(flatten),为一维字典,就可以用多重列表解析方法:

data = {'A':[1, 2, 3], 'B':[4, 5, 6], 'C':[7, 8, 9]}

想要拉伸成一维的线性结构如下:

data = [{'A': 1}, {'A': 2}, {'A': 3}, {'C': 7}, {'C': 8}, {'C': 9}, {'B': 4}, {'B': 5}, {'B': 6}]

for 循环方法

可以用二重循环方法:

new = []
for key in data:
    for item in data[key]:
        new.append({key:item})

# new = [{'A': 1}, {'A': 2}, {'A': 3}, {'C': 7}, {'C': 8}, {'C': 9}, {'B': 4}, {'B': 5}, {'B': 6}]

列表解析方法

用二维列表解析同样可以实现。注意:列表解析中的for 的顺序 for key in data for item in data[key] 和普通的写法一致 :

[{key:item} for key in data for item in data[key]]

# [{'A': 1}, {'A': 2}, {'A': 3}, {'C': 7}, {'C': 8}, {'C': 9}, {'B': 4}, {'B': 5}, {'B': 6}]

再看两个二维列表的例子:

例子1

data = [[0, 1, 2], [3, 4, 5], [6, 7, 8]]
new = [y for x in data for y in x]
# new 等于 [0, 1, 2, 3, 4, 5, 6, 7, 8]

例子2

data = [[0, 1, 2], [4, 5], [6]]
new = [y for x in data for y in x]
# new 等于 [0, 1, 2, 4, 5, 6]

捐助本站

为了保证阅读体验,本站不安放广告。但是,租用服务器和编写文章需要个人资金和时间的投入。

如果您觉得文章对您有用,请考虑捐助小站(金额不限),以期待更多原创文章。捐助记录

本站是个人网站,若无特别说明,文章均为原创,并采用 署名协议 CC-BY-NC 授权。
欢迎转载,惟请保留原文链接,且不得用于商业用途。