Python中itertools库的四个函数介绍

作者:sgzqc 时间:2021-05-04 14:34:05 

1. 引言

在Python开发中,itertools库经常被忽视,实际上该库中抱恨了一些非常棒的函数,特别是用于处于数据流的函数。在本文中,我们将讨论该库中的十分使用的几个函数,并重点介绍什么时候我们应该考虑使用它们。
闲话少说,我们直接开始吧!

2. accumulate() 函数

第三方库itertools提供的函数accumulate(),可以帮助我们对数据流执行累积操作。换句话说,假设我们有一个数据列表[a,b,c,d,e]和一个运算f,那么函数accumulate()可以帮助我们计算f(a,b)f(f(a,b),c)f(f(f(a,b),c),d),等等。
文字有点不直观,那我们来举个累加的栗子吧!

样例代码如下:

import itertools
data = [3, 4, 6, 2, 1, 9, 0, 7, 5, 8]

res = itertools.accumulate(data, lambda x,y:x+y)
print(list(res))
# [3, 7, 13, 15, 16, 25, 25, 32, 37, 45]

上述函数accumulate()的作用是:先把3和4相加,然后得到7,再和6相加,得到另一个值,依此类推。

需要注意的是:如果要执行给定3个或更多值的累计操作,则不允许使用该函数,因为accumulate()只接受迭代器,迭代器每次调用next()返回至多1个元素。

3. compress() 函数

函数compress()可以根据我们的喜好来过滤内容。与函数filter()函数不同,函数compress()需要传入相应的标志位来决定是否应该保留每个值。

举个例子会更加直观,相关样例代码如下:

import itertools
data = [3, 4, 6, 2, 1, 9, 0, 7, 5, 8]
selector = [1, 0, 0, 0, 1, 1, 0, 1, 1, 0]
res = itertools.compress(data, selector)
print(list(res))
# [3, 1, 9, 7, 5]

在上面的示例中,如果数据是奇数,则选择器将为 1,否则为 0。因此,函数compress() 操作的结果将只是保留原始数据中的奇数。

4. groupby() 函数

在许多情况下,我们会在 Python 中以随机顺序获得一个元组列表,假如我们希望按值对它们进行分组。此时是函数 groupby() 发挥作用的完美场景!

函数 groupby() 将接受一个可迭代的参数和一个返回值的函数,然后它将按函数返回的值对元组列表进行分组。

例如,我们想按国家对以下城市进行分组:

import itertools

data = [('New York', 'US'), ("Shanghai", "China"),
("LA", 'US'),("Chongqing", "China")]

for city, group in itertools.groupby(sorted(data, key=lambda x: x[1]), lambda x: x[1]):
for i in group:
print("%s is in %s." % (i[0], city))
print("")

# Shanghai is in China.
# Chongqing is in China.

# New York is in US.
# LA is in US.

5. 排列组合操作

排列组合可能是 itertools库中最令人惊叹的函数之一,它提供了排列组合运算符!
我们唯一需要做的就是将正确的关键字与输出元组的长度一起传递给相应的函数,

如下例所示:

import itertools
data = [3, 4, 6]

com_res = itertools.combinations(data, 2)
print(list(com_res))
# [(3, 4), (3, 6), (4, 6)]

com_res = itertools.permutations(data, 2)
print(list(com_res))
# [(3, 4), (3, 6), (4, 3), (4, 6), (6, 3), (6, 4)]

com_without_replacement_res = itertools.combinations_with_replacement(data, 2)
print(list(com_without_replacement_res))
# [(3, 3), (3, 4), (3, 6), (4, 4), (4, 6), (6, 6)]

product_res = itertools.product(data, data)
print(list(product_res))
# [(3, 3), (3, 4), (3, 6), (4, 3), (4, 4), (4, 6), (6, 3), (6, 4), (6, 6)]

6 总结

itertools对大多数人来说,是一个未被充分利用甚至很少听到的库,但它确实包含一些非常好用的函数。这些函数通常可以帮助我们将代码行数减少到仅一行,使我们的代码看起来更加简洁优雅!

来源:https://blog.51cto.com/u_15506603/5165526

标签:Python,itertools,库,函数
0
投稿

猜你喜欢

  • 在Python中os.fork()产生子进程的例子

    2022-08-12 18:15:27
  • 常用java正则表达式的工具类

    2023-06-14 09:16:46
  • ASP中的301跳转和302跳转

    2008-08-06 18:40:00
  • php bugs代码审计基础详解

    2023-06-02 13:49:52
  • Python对文件操作知识汇总

    2023-02-26 11:10:59
  • Python爬取APP下载链接的实现方法

    2022-04-10 02:12:27
  • python接口调用已训练好的caffe模型测试分类方法

    2021-08-11 18:31:04
  • 搭建 Selenium+Python开发环境详细步骤

    2022-10-12 17:34:02
  • 解析xml字符串的函数

    2008-06-10 12:37:00
  • Python数据库反向生成Model最优方案示例

    2023-11-02 18:37:36
  • Python BeautifulSoup中文乱码问题的2种解决方法

    2023-05-09 13:42:17
  • Django框架静态文件使用/中间件/禁用ip功能实例详解

    2023-06-12 02:48:38
  • 在ASP.NET 2.0中操作数据之五十二:使用FileUpload上传文件

    2023-07-07 04:19:18
  • 在ipython notebook中使用argparse方式

    2021-11-17 08:58:41
  • python3使用pandas获取股票数据的方法

    2023-01-04 15:01:15
  • Python无头爬虫下载文件的实现

    2023-11-30 03:24:00
  • PHP 实现多服务器共享 SESSION 数据

    2023-11-19 12:43:24
  • 网页版面布局的处理问题

    2008-06-05 12:32:00
  • asp实现*号隐藏IP地址

    2008-08-10 18:51:00
  • Python实现获取磁盘剩余空间的2种方法

    2023-11-20 23:53:29
  • asp之家 网络编程 m.aspxhome.com