gpt4 book ai didi

python - 使用产量生成器从列表中删除连续的重复项?

转载 作者:行者123 更新时间:2023-12-03 18:10:23 25 4
gpt4 key购买 nike

关闭。这个问题需要debugging details .它目前不接受答案。












想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。

去年关闭。




Improve this question




我正在尝试使用生成器压缩列表:
例子

[1, 1, 1, 1, 2, 2, 2, 1, 1, 1] == [1, 2, 1]

[5, 5, 5, 4, 5, 6, 6, 5, 5, 7, 8, 0, 0])) == [5, 4, 5, 6, 5, 7, 8, 0]
我尝试使用一个生成器来检查第 1 个和第 2 个元素是否相等,然后检查第 2 个和第 3 个元素,依此类推,直到它不再相等“当它达到 4”然后产生“5”然后它会重复从“4”
代码
test = [5, 5, 5, 4, 5, 6, 6, 5, 5, 7, 8, 0, 0] # sample list
from typing import Iterable
def compress(items: list) -> Iterable:

x = 0
while items[x] == items[x + 1]:
x += 1
yield items[x]


ans = compress(test)
for x in ans:
print(ans)
但我不断得到
生成器对象压缩在 0x00000254D383C820。
为什么它不会循环?
如果我尝试使用 next() 它只会增加到 5 并且不会检查其他数字。
非常感谢任何帮助。

最佳答案

正如其他人所解释的那样,您的结构不正确 - 您只会在循环外遇到一次产量。理想的方法是迭代成对的连续数字,如果它们不同,则产生循环中的第一个。

但是,这里有一个规范的方法,通过 itertools.groupby 删除连续的重复项:

from itertools import groupby 
from operator import itemgetter

list(map(itemgetter(0), groupby(l)))
# [1, 2, 1]

关于python - 使用产量生成器从列表中删除连续的重复项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62122481/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com