python - 嵌套列表结构中的聚合数据

标签 python list lambda aggregation

我有一个具有以下结构的嵌套子列表的列表

in_data = 
 [
   [
     ['name', 'name_1'],  
     ['item_B', '2'], 
     ['item_C', '3'], 
     ['item_D', '4']
   ],
   [
     ['name', 'name_2'], 
     ['item_B', '5'], 
     ['item_A', '2']
   ],
   [
     ['name', 'name_3'], 
     ['item_B', '6'], 
     ['item_C', '7']
   ]
]

我正在尝试收集 in_data 中的所有数据并制作一个包含子列表的唯一列表,一个用于所有“标题”/名称 并且每个项目一个 + 正确顺序的值。 因此信息得以保留,但在不同的数据结构中。

我要实现这个列表:

res_list = 
[
  ['name', ' name_1', ' name_2', 'name_3'], 
  ['item_B', '2', '5', '6'], 
  ['item_C', '3','-', '7'], 
  ['item_D', '4','-', '-'], 
  ['item_A', '-','2', '-'] 
]

我正在尝试以最 pythonic 的方式来做。我尝试使用 for 循环和 map() + lambda 但没有成功。

会是简单的方法吗?

最佳答案

优化方法(由复合字典键 (<skill name>, <column name>)dict.get 方法提供支持):

header = ['names']
names = set()
d = {}

for lst in in_data:
    col_name = lst[0][-1]
    header.append(col_name)
    for name, val in lst[1:]:
        names.add(name)
        d[name, col_name] = val

res = [[n, *[d.get((n, h), '-') for h in header[1:]]] for n in names]
res.insert(0, header)
print(res)

输出:

[['names', 'name_1', 'name_2', 'name_3'],
 ['item_C', '3', '-', '7'],
 ['item_D', '4', '-', '-'],
 ['item_B', '2', '5', '6'],
 ['item_A', '-', '2', '-']]

关于python - 嵌套列表结构中的聚合数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58790424/

相关文章:

python-3.x - 使用 Python 3.6 和密码学模块部署 AWS Lambda 包

java - 使用Java 8新API的CollectionUtills编译报错

python os.path.exists() 找不到文件但是文件确实存在

python - 查找由 Pandas 中的列表元素组成的系列的模式

java - 我想通过多线程将此函数作为列表中所有值的线程执行,请指导我

list - Clojure 函数抛出空指针异常

java - 使用 Java 8 流如何将 Map<String, List<Something>> 转换为 Map<String, Integer>?

python - 了解切片

Python:在 Facet 网格中绘制堆积条形图

python - 将我的实时输出打印到txt文件不起作用python