在 Python 中计算列表中的重复项

要计算列表中的重复项:

  1. 使用 dict 理解来迭代列表。
  2. 使用 list.count() 方法计算每个项目的出现次数。
  3. 将每个项目作为键返回,将出现次数作为值返回。
my_list = ['one', 'one', 'two', 'two', 'three']

my_dict = {
    item: my_list.count(item) for item in my_list
}
print(my_dict)  # ?️ {'one': 2, 'two': 2, 'three': 1}

# -------------------------------

total_count = len(my_list) - len(set(my_list))
print(total_count)  # ?️ 2

在 Python 中计算列表中的重复项

我们使用 dict 推导来迭代列表。

字典推导对字典中的每个键值对执行一些操作,或者选择满足条件的键值对子集。

在每次迭代中,我们使用 list.count() 方法来获取项目包含在列表中的次数。

list.count() 方法接受一个值并返回提供的值出现在列表中的次数。

print(['zadmei', 'zadmei', 'com'].count('zadmei'))  # ?️ 2
print(['zadmei', 'zadmei', 'com'].count('another'))  # ?️ 0

新字典包含每个列表项作为键,出现次数作为值。

my_list = ['one', 'one', 'two', 'two', 'three']

my_dict = {
    item: my_list.count(item) for item in my_list
}
print(my_dict)  # ?️ {'one': 2, 'two': 2, 'three': 1}

如果我们需要获取列表中重复项的总数,请将列表转换为集合,然后从列表的长度中减去集合的长度。

my_list = ['one', 'one', 'two', 'two', 'three']


total_count = len(my_list) - len(set(my_list))
print(total_count)  # ?️ 2

我们使用 set() 类将列表转换为集合对象。

集合对象是唯一元素的无序集合,因此将列表转换为集合会删除所有重复项。

通过从列表的长度中减去集合的长度,我们得到列表中重复的总数。

或者,我们可以使用 collections.Counter() 类。


使用 collections.Counter 计算列表中的重复项

使用 collections.Counter() 类计算列表中的重复项,例如 my_dict = dict(Counter(my_list))。 Counter 类将返回一个类似字典的对象,其中包含作为键的列表项和作为值的出现次数。

from collections import Counter

my_list = ['one', 'one', 'two', 'two', 'three']

my_dict = dict(Counter(my_list))
print(my_dict)  # ?️ {'one': 2, 'two': 2, 'three': 1}

在 Python 中计算列表中的重复项

collections 模块中的 Counter 类是 dict 类的子类。

该类基本上是键计数对的映射。

这些值可以是任何整数(包括零和负数)。

from collections import Counter

my_list = ['one', 'one', 'two', 'two', 'three']

# ?️ Counter({'one': 2, 'two': 2, 'three': 1})
print(Counter(my_list))

my_dict = dict(Counter(my_list))
print(my_dict)  # ?️ {'one': 2, 'two': 2, 'three': 1}

我们使用 dict 类将 Counter 对象转换为字典。

或者,我们可以使用 for 循环。

使用 for 循环计算列表中的重复项

要计算列表中的重复项:

  1. 使用 set() 类将列表转换为集合。
  2. 使用 for 循环遍历集合。
  3. 将每个列表项指定为字典中的键,并将其出现次数指定为值。
my_list = ['one', 'one', 'two', 'two', 'three']

my_dict = {}

for item in set(my_list):
    my_dict[item] = my_list.count(item)

print(my_dict)  # ?️ {'three': 1, 'one': 2, 'two': 2}

我们使用 set() 类从列表中删除所有重复项,并使用 for 循环遍历 set 对象。

这为我们节省了几次迭代和几次对 list.count() 方法的调用。

在每次迭代中,我们将当前项目指定为字典中的键,并将其在列表中的出现次数指定为值。