python - 字典迭代

标签 python

我得到了这个数据集,并负责提出一个循环来查找该字典中的最高值。我很困惑为什么将 print 函数放置在循环(#1)内会产生与将其放置在循环(#2)外不同的答案。

data = {'Jeremy':73284, 'Hansel':8784.3, 'Uee':9480938.2,
        'Seolhyun':984958.3, 'Ketsuno Ana':24131, 'Trump':45789}

highest_network = data["Jeremy"]

for key,value in data.items():
    if value > highest_network:
        highest_network = value
        print(key,value) #1 


print(key,value) #2

抱歉,我还是 python 的初学者,因此我对某些概念仍然不是很熟悉。

最佳答案

在执行期间的任何给定时间,Python 都会保留本质上存在的变量名及其值的字典。它与作用域交互的方式有点令人困惑/复杂,但足以说明在这种情况下,keyvalue 是在 的作用域中声明的在 for 循环之外

现在,请注意第一个 print 语句。由于它位于循环内部,并且 keyvalue 将不断更新,因此它将打印当前的 keyvalue 每次执行时。

第二个 print 语句位于循环之外,并在循环运行后执行。请记住,变量 keyvalue 仍在范围内,并且仍然保留最后分配给它们的内容(在本例中) 、keyvalue 将是您从 data.items() 获得的最后一个值。这就是为什么它们的行为不同 - 因为每次尝试打印时 keyvalue 的值都不同。

请记住,就标准而言,data.items() 放置数据的顺序实际上是任意的。每个键通过 for 循环的顺序在您的计算机上每次运行都是一致的,但如果您将相同的代码放在其他人的计算机上,则可能会出现以下情况:采取不同的行动。因此,您不应依赖此行为的一致性。

关于python - 字典迭代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51503677/

相关文章:

python - 无需手动输入即可读取文件名列表

python - 在 Python 中使用 os.walk 查找大于 300MB 的文件?

python - 为什么 `docker run -t` 可以使 python 刷新输出缓冲区?

python - tensorflow 的 tables_initializer 有什么作用?

python - 如何使用 elasticsearch-dsl 在嵌套查询周围添加 OR 过滤器

python - 在 MySQL 数据库中插入 python 元组

python - 当最终网址为 https 时,如何使用 python 取消缩短(解析)网址?

python - 删除默认 Python 2.7 后在 CentOS 上重新安装 Python

javascript - 无法从 selenium execute_script 访问 chrome 消息传递 API

python - 将 numpy runtimewarning 捕获为异常并抑制它们