识别列表中连续重复项的最 Python 方式是什么?
- 2025-02-20 09:24:00
- admin 原创
- 66
问题描述:
我有一个整数列表,我希望能够识别连续的重复块:也就是说,我希望生成一个保序的重复项列表,其中每个重复项包含(int_in_question,出现次数)。
例如,如果我有如下列表:
[0, 0, 0, 3, 3, 2, 5, 2, 6, 6]
我想要的结果是:
[(0, 3), (3, 2), (2, 1), (5, 1), (2, 1), (6, 2)]
我有一个相当简单的方法来实现这一点,即使用 for 循环、温度和计数器:
result_list = []
current = source_list[0]
count = 0
for value in source_list:
if value == current:
count += 1
else:
result_list.append((current, count))
current = value
count = 1
result_list.append((current, count))
但我非常喜欢 Python 的函数式编程习惯用法,我希望能够使用简单的生成器表达式来实现这一点。但是我发现在使用生成器时很难保持子计数。我觉得两步流程可能会让我实现这一点,但目前我不知所措。
有没有一种特别优雅/ Pythonic 的方法来做到这一点,尤其是使用生成器?
解决方案 1:
>>> from itertools import groupby
>>> L = [0, 0, 0, 3, 3, 2, 5, 2, 6, 6]
>>> grouped_L = [(k, sum(1 for i in g)) for k,g in groupby(L)]
>>> # Or (k, len(list(g))), but that creates an intermediate list
>>> grouped_L
[(0, 3), (3, 2), (2, 1), (5, 1), (2, 1), (6, 2)]
正如他们所说,包含电池。
sum
JBernardo 的使用和生成器表达式的建议;参见评论。
相关推荐
热门文章
项目管理软件有哪些?
热门标签
曾咪二维码
扫码咨询,免费领取项目管理大礼包!
云禅道AD