求求你了,不要再写循环求两个列表的交集,并集和差集了 | pythonic 小技巧

在 Python 中,求两个列表的交集,并集和差集是经常会遇到的需求,而且也比较简单。

最容易想到的就是写循环,对两个列表分别进行循环,然后判断元素是否在另一个列表中,求得最终结果。

但这种方法比较 low,没啥技术含量。身为一名 Python 程序员,一定要写够 pythonic 的代码。

废话不多说,直接看代码。

# list_operate.py

def main():
    list_a = [1, 2, 3, 4, 5]
    list_b = [4, 5, 6, 7, 8]

    # 求交集的两种方式
    res_a = [i for i in list_a if i in list_b]
    res_b = list(set(list_a).intersection(set(list_b)))

    print(f"res_a is: {res_a}")
    print(f"res_b is: {res_b}")

    # 求并集
    res_c = list(set(list_a).union(set(list_b)))
    print(f"res_c is: {res_c}")

    # 求差集的两种方式,在B中但不在A中
    res_d = [i for i in list_b if i not in list_a]
    res_e = list(set(list_b).difference(set(list_a)))

    print(f"res_d is: {res_d}")
    print(f"res_e is: {res_e}")


if __name__ == '__main__':
    main()

来看一下输出:

# python3 list_operate.py
res_a is: [4, 5]
res_b is: [4, 5]
res_c is: [1, 2, 3, 4, 5, 6, 7, 8]
res_d is: [6, 7, 8]
res_e is: [8, 6, 7]

结果还是没问题的,别一顿操作猛如虎,结果是错的,那就尴尬了。

总结一下,基本上就是两种思路:

  1. 使用列表表达式
  2. 使用 set 的内置方法,再转换成 list

以上。

关注公众号 AlwaysBeta,学习更多 pythonic 小技巧。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 在python3对列表的处理中,会经常使用到Python求两个list的差集、交集与并集的方法。 一.两个list...
    极客与宽客阅读 8,996评论 0 0
  •   今天在做项目的时候遇到一个问题,给定一组点,如何方便快捷的求出点之间的距离。比如总共有100个点,两两组合求距...
    阿玖yy阅读 7,938评论 0 6
  • 久违的晴天,家长会。 家长大会开好到教室时,离放学已经没多少时间了。班主任说已经安排了三个家长分享经验。 放学铃声...
    飘雪儿5阅读 12,238评论 16 22
  • 创业是很多人的梦想,多少人为了理想和不甘选择了创业来实现自我价值,我就是其中一个。 创业后,我由女人变成了超人,什...
    亦宝宝阅读 5,866评论 4 1
  • 今天感恩节哎,感谢一直在我身边的亲朋好友。感恩相遇!感恩不离不弃。 中午开了第一次的党会,身份的转变要...
    余生动听阅读 13,602评论 0 11

友情链接更多精彩内容