在python中的同一项内出现计数器

时间:2018-03-01 17:18:02

标签: python group-by counter

抱歉,我很确定其他人可能已经问过这个问题,但我没有找到。我想跟踪我看过这个特定项目的次数,例如

输入:

[88,88,27,0,88]

期望的输出:

[1,2,1,1,3]

我正在寻找性能方面特别好的东西。 我对Numpy或Pandas解决方案感到满意。

4 个答案:

答案 0 :(得分:3)

这是一种使用列表理解的简单方法:

x = [8,1,2,3,1,3,3,1,2,99]
y = [x[:i].count(el) + 1 for i, el in enumerate(x)]
print(y)

输出:

[1, 1, 1, 1, 2, 2, 3, 3, 2, 1]

答案 1 :(得分:2)

lst = [8,1,2,3,1,3,3,1,2,99]

cnt = {}
res = []

for x in lst:
    cnt[x] = cnt.get(x,0)+1
    res += [cnt[x]]

print(res)

输出

答案 2 :(得分:1)

>>> from collections import defaultdict
... 
... 
... def solution(lst):
...     result = []
...     seen = defaultdict(int)
...     for num in lst:
...         seen[num] += 1
...         result.append(seen[num])
...     return result
... 
>>> solution([88, 88, 27, 0, 88])
[1, 2, 1, 1, 3]
>>> solution([8, 1, 2, 3, 1, 3, 3, 1, 2, 99])
[1, 1, 1, 1, 2, 2, 3, 3, 2, 1]

没有进口:

>>> def solution(lst):
...     result = []
...     seen = {}
...     for num in lst:
...         try:
...             seen[num] += 1
...         except KeyError:
...             seen[num] = 1
...         result.append(seen[num])
...     return result
... 
>>> solution([88, 88, 27, 0, 88])
[1, 2, 1, 1, 3]
>>> solution([8, 1, 2, 3, 1, 3, 3, 1, 2, 99])
[1, 1, 1, 1, 2, 2, 3, 3, 2, 1]

答案 3 :(得分:1)

发电机之一:

def return_count(l):
    cnt = {}
    for x in l:
        cnt[x] = cnt.get(x, 0) + 1
        yield cnt[x]

print(list(return_count([8, 1, 2, 3, 1, 3, 3, 1, 2, 99])))