首页
学习
活动
专区
圈层
工具
发布

Python小技之组合不同列表, 获取所有结果

Python的前辈们封装了非常多的特别简单又高效的方法 只不过不常用, 也不知道而已 今天就介绍下itertools的product函数 list_a = [1, 2, 3] list_b = [",...list_c = ["a", "b", "c"] 正常情况下, 如果要找出上面几个列表共有多少种组合, 我们要以下这样 for a in list_a: for b in list_b:...如果只有三个循环的话, 这样写也没什么, 如果20个呢, 上百个呢, 结果可想而知, 一个长达几百行的循环 接下来, 就是我们的神器出场了 上面那个例子, 摇身一变 import itertools...如果是循环相同的迭代器, 还可以这样写 for a,b,c in itertools.product(list_a, repeat=3): print(f"{a}{b}{c}") 结果如下:...注意: itertools.product(), 这里其实得到的是一个元组, 例(1,1,1)(1,1,2).... 好了, 今天这个神奇的模块就到这里了, 你get到了嘛?

1.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Excel实战技巧62: 获取不重复的值作为数据验证列表项

    然而,细心的朋友可能注意到,在单元格H1的下拉列表中,原原本本地照搬了列A中的数据,其中有很多重复项,这显然是我们所不需要的。 如何基于已有数据在数据验证列表中填充不重复的数据项呢?...方法1:使用公式获取不重复值 如下图3所示,选择单元格E2,输入用于获取不重复值的数组公式,然后下拉至数据末尾,得到不重复项列表。 ?...方法2:利用数据透视表获取不重复值 选择单元格E1,插入数据透视表,数据源为数据区域A1:A14,得到结果如下图5所示。 ?...方法3:使用Office365中的新功能—动态数组 选择单元格F1,输入公式: =SORT(UNIQUE(表1[名称])) 此时,Excel会自动将列中的不重复值分别输入到下面相邻的单元格中,如下图6所示...实际上,对于Office 365来说,在定义命名公式时还有一种更简单的方法,如下图7所示,直接在“引用位置”输入:=F1#,告诉Excel想要获取该列完整的数据。 ?

    8.2K10

    Python中如何获取列表中重复元素的索引?

    一、前言 昨天分享了一个文章,Python中如何获取列表中重复元素的索引?,后来【瑜亮老师】看到文章之后,又提供了一个健壮性更强的代码出来,这里拿出来给大家分享下,一起学习交流。...= 1] 这个方法确实很不错的,比文中的那个方法要全面很多,文中的那个解法,只是针对问题,给了一个可行的方案,确实换个场景的话,健壮性确实没有那么好。 二、总结 大家好,我是皮皮。...这篇文章主要分享了Python中如何获取列表中重复元素的索引的问题,文中针对该问题给出了具体的解析和代码演示,帮助粉丝顺利解决了问题。...最后感谢粉丝【KKXL的螳螂】提问,感谢【瑜亮老师】给出的具体解析和代码演示。

    18.2K10

    【Python】基于多列组合删除数据框中的重复值

    最近公司在做关联图谱的项目,想挖掘团伙犯罪。在准备关系数据时需要根据两列组合删除数据框中的重复值,两列中元素的顺序可能是相反的。...本文介绍一句语句解决多列组合删除数据框中重复值的问题。 一、举一个小例子 在Python中有一个包含3列的数据框,希望根据列name1和name2组合(在两行中顺序不一样)消除重复项。...import numpy as np #导入数据处理的库 os.chdir('F:/微信公众号/Python/26.基于多列组合删除数据框中的重复值') #把路径改为数据存放的路径 df =...从上图可以看出用set替换frozense会报不可哈希的错误。 三、把代码推广到多列 解决多列组合删除数据框中重复值的问题,只要把代码中取两列的代码变成多列即可。...numpy as np #导入数据处理的库 os.chdir('F:/微信公众号/Python/26.基于多列组合删除数据框中的重复值') #把路径改为数据存放的路径 name = pd.read_csv

    19.3K30

    【Redis】Redis 列表 List 操作 ( 查询操作 | 根据下标获取元素 | 获取列表长度 | 增操作 | 插入值 | 删操作 | 移除值 | 修改操作 | 设置列表指定索引的值 )

    文章目录 一、List 列表简介 二、查询操作 1、根据下标获取元素 2、获取指定下标索引的元素 3、获取列表长度 三、增操作 1、插入值 2、在指定元素前后插入值 四、删操作 1、移除值 2、...指向元素的实际内存空间 ; 同时还有 指向 前一个元素 和 后一个元素的 指针 ; 快速链表 是 链表 和 压缩列表 结合起来的产物 ; 二、查询操作 ---- 1、根据下标获取元素 根据下标获取元素...: 获取从 start 索引开始 , 到 stop 索引结束的元素值 ; lrange key start stop key : 键 ; start : 元素的起始索引值 ; stop : 元素的终止索引值...移除值 : 从左侧移除值 : 从 List 列表左侧移除一个值 , 如果所有的值都被移除 , 则 键 Key 也随之消亡 ; lpop key 从右侧移除值 : 从 List 列表右侧移除一个值 ,...如果所有的值都被移除 , 则 键 Key 也随之消亡 ; rpop key 如果要 查询 键 对应的 List 列表值 , 使用 lrange key 0 -1 命令即可 ; 代码示例 : 127.0.0.1

    8.2K10

    Excel公式技巧68:查找并获取所有匹配的值

    学习Excel技术,关注微信公众号: excelperfect 在《Excel公式技巧67:按条件将数据分组标识》中,我们根据指定的条件采用数字标识将数据进行了分组。...利用这列分组数据,我们能方便地查找并获取所有匹配的值。 如下图1所示的工作表,我们想查找商品名称是“笔记本”且在区域A的所有数据。 ?...可以看到,工作表中以商品名称是“笔记本”且在区域A的数据行为分界点连续编号。 在单元格G3中输入公式: =MAX(E3:E20) 得到共有多少个满足条件的查找值。...公式很简单,其关键在于: MATCH(G6,E3:E 查找到第n个(由列G中的单元格指定)匹配的值所在的位置。 而COLUMNS($H6:H6)则返回要获取的值所在列的位置。...如果使用定义的名称,则公式更加简洁,如下图2所示。 ? 图2 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。 欢迎到知识星球:完美Excel社群,进行技术交流和提问,获取更多电子资料。

    12.1K10

    Excel公式练习56: 获取重复次数最多的值

    学习Excel技术,关注微信公众号: excelperfect 本次的练习是:给定一个单元格区域,要求使用公式得到该区域中重复次数最多的值。...如下图1所示,在单元格区域A1:F1中,重复次数最多的数据是“完美Excel”。 ? 图1 先不看答案,自已动手试一试。...公式解析 在《Excel公式练习55:获取重复数据出现的最大次数》中,我们已经知道,公式中的COUNTIF函数可生成数组: {2,3,3,2,1,3} 这样,公式中的: MATCH(MAX(COUNTIF...2,3,3,2,1,3}),{2,3,3,2,1,3},0) 转换为: MATCH(3,{2,3,3,2,1,3},0) 得到: 2 代入主公式中,得到: =INDEX(A1:F1, 2) 结果为单元格B1中的值...: =INDEX(A1:F1,1,MATCH(MAX(COUNTIF(A1:F1,A1:F1)),COUNTIF(A1:F1,A1:F1),0)) 扩展 将本文的示例与《Excel公式练习55:获取重复数据出现的最大次数

    3.2K11

    一日一技:如何用Python遍历多个列表元素的所有组合

    大家小时候可能玩过“谁”-“什么时候”-“在哪里”-“干什么”的游戏,这个游戏用Python来表述是这样的: import randomwho = ['王小一', '张小二', '李小三', '朱小四...现在,我想知道这些句子一共有哪些组合,应该怎么办呢?...最常见的写法是嵌套4个for循环: who = ['王小一', '张小二', '李小三', '朱小四']when = ['早上8点', '下午3点', '凌晨2点']where = ['在厕所','在卧室...在Python中,对于这种情况,有现成的处理方法,那就是 itertools.product计算可迭代对象的笛卡尔积。...itertools.product可以接收非常无数个可迭代的对象,然后把他们想for循环嵌套一样拼接起来。

    16.7K40
    领券