嵌套列表的逐元素总和

Element-wise sum of nested lists

我有一个名为 list_6 的嵌套列表:

[[-1, 1, -1, 1, -1, 1, 1, 0, -1, 0, -1, -1, 1, 1, 1, 0, 1, -1, -1, -1, 1, 1, 1, 0, 0, -1, 0, 0, 0, 1, 0, -1, 1, 1, -1, 0, 0, 1, 1, -1, 0, -1, 1, 1, -1, 1, -1, -1, -1, 1, -1],...]]

列表中的每个元素都是-1,1的整数,且元素长度不等,列表中有20个元素

我想创建一个名为 list_7 的新列表,如下所示:

[[13],[4],[5],...]], 这样嵌套列表中的每个元素都被求和,并打印结果。我尝试使用 iter.zip_longest:

[sum(i) for i in itertools.zip_longest(*list_6, fillvalue=0)]

但我得到一个错误函数:

'str' 对象不可调用

您可以使用列表理解来做到这一点 https://www.programiz.com/python-programming/list-comprehension

list_7 = [sum(inner_list) for inner_list in list_6]

在方括号 ([]) 中,您正在迭代 list_6 中的每个项目。 由于 list_6 中的每个项目本身就是一个列表 (inner_list),我们可以在列表中调用 python 的 sum 函数来获取 [=12] 中值的总和=] https://www.w3schools.com/python/ref_func_sum.asp.

我现在看到您正在寻找自己列出的总和 ([[13],[4],[5],...]],),在这种情况下您会想要这样做:

list_7 = [[sum(inner_list)] for inner_list in list_6]

sum(inner_list) 括起来会创建一个新列表,其唯一条目是 inner_list.

的总和