嵌套列表的逐元素总和
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.
的总和
我有一个名为 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.