带有 if 子句的列表理解如何工作?

How does list comprehension with an `if` clause work?

max_list 变量列表理解如何工作?

def mode(*args):
    dict_vals = {i: args.count(i) for i in args}
    max_list = [k for k, v in dict_vals.items() if v == max(dict_vals.values())]
    return max_list

我知道 dict_vals 创建了一个字典,其中包含您输入的值(键)和每个值的出现次数(键的值)。我也知道 max_list 根据最大​​值(出现次数)创建出现次数最多的键(值)列表。 我只是想知道 max_list 中使用的理解是如何工作的,也许还有其他一些将字典转换为具有类似语法的列表以用于有用应用程序的示例。另外,是否有类似的方法来处理元组?

max_list = [k for k, v in dict_vals.items() if v == max(dict_vals.values())]

做类似的事情:

max_list = []
for k,v in dict_vals.items():
    if v == max(dict_vals.values()):
        max_list.append(k)

列表理解中的第一个变量(在本例中为 k)始终是列表中的内容。最后的条件检查是否应添加循环中的当前项目。如果你想把结果放在一个元组中,我相信你只是把外面包裹在一个元组中(一个简单的括号是行不通的,因为解释器可能认为你只是在对操作进行分组)。

max_list = tuple(k for k, v in dict_vals.items() if v == max(dict_vals.values()))
dict_vals.items()

items() 方法生成字典中的每个 key-value 对。

k, v in dict_vals.items()

这将迭代 items()

生成的字典中的每个 key-value 对
k, v in dict_vals.items() if v == max(dict_vals.values())

这通过仅选择值等于存储在 dict_vals 中的最大值的那些对来过滤 key-value 对的列表(.values() 为您提供所有值 & max() 找到其中最大的)。

最后,

k for k,v in dict_vals.items() if v == max(dict_vals.values())

仅为这些对选择密钥 (k)。 [] 使其成为列表。