Python实现对规整的二维列表中每个子列表对应的值求和

Python爬虫与数据挖掘

共 1614字,需浏览 4分钟

 ·

2022-04-27 22:38

点击上方“Python爬虫与数据挖掘”,进行关注

回复“书籍”即可获赠Python从入门到进阶共10本电子书

别来沧海事,语罢暮天钟。

大家好,我是Python进阶者。

一、前言

前几天在Python白银交流群有个叫【dcpeng】的粉丝问了一个Python列表求和的问题,如下图所示。

代码如下:

lst = [[1, 2, 3, 4], [1, 5, 1, 2], [2, 3, 4, 5], [5, 3, 1, 3]]
s1 = 0
s2 = 0
s3 = 0
s4 = 0
for i in lst:
    s1 += i[0]
    s2 += i[1]
    s3 += i[2]
    s4 += i[3]
print(list([s1, s2, s3, s4]))

上面的这个代码可以实现,但是觉得太不智能了,如果每个子列表里边有50个元素的话,再定义50个s变量,似乎不太好,希望可以有个更加简便的方法。

二、实现过程

关于这个题目,大佬们一共给了3种方法,这里整理出来,给大家一起学习。

【瑜亮老师】解法

这里【瑜亮老师】给了一个代码,如下所示:

lst = [[1, 2, 3, 4], [1, 5, 1, 2], [2, 3, 4, 5], [5, 3, 1, 3]]

[print(sum(i)) for i in zip(*lst)]

使用了列表解包的方法,完成了需求,确实很赞。

【Daler】解法

一开始【猫药师Kelly】大佬给了一个思路,使用np array实现,后来【Daler】直接安排了一份代码,如下所示:

import numpy as np

lst = [[1, 2, 3, 4], [1, 5, 1, 2], [2, 3, 4, 5], [5, 3, 1, 3]]

list1 = np.sum(lst, axis=0)  # 按照纵轴计算
list2 = np.sum(lst, axis=1)  # 按照横轴计算
print(list1)
print(list2)

这里使用numpy库进行实现,也非常赞!

【月神】解法

这里【月神】给了一个难顶的解法,使用了内置函数和匿名函数来实现,代码如下所示:

from functools import reduce

lst = [[1, 2, 3, 4],
      [1, 5, 1, 2, 6],
      [2, 3, 4, 5],
      [5, 3, 1, 3]]

print(list(reduce(lambda x, y: map(lambda i, j: i + j, x, y), lst)))

以上就是针对该问题的三个解决方法了,真是太强了!如果你还有其他方法,欢迎尝试,有结果的话,欢迎分享给我噢!

三、总结

大家好,我是Python进阶者。这篇文章主要分享了使用Python实现对规整的二维列表中每个子列表对应的值求和的问题,文中针对该问题给出了具体的解析和代码演示,一共3个方法,顺利帮助粉丝顺利解决了问题。

最后感谢粉丝【dcpeng】提问,感谢【瑜亮老师】、【月神】、【Daler】给出的代码和具体解析,感谢粉丝【猫药师Kelly】等人参与学习交流。

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何Python问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

------------------- End -------------------

往期精彩文章推荐:

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【

万水千山总是情,点个【在看】行不行

浏览 17
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报