想要获得字典a中各科成绩的降序排名,代码如下。
a = {'math':98, 'english':100, 'PE':77}
b = sorted(a.iteritems(), key=operator.itemgetter(1), reverse=True)
c = sorted(a.items(), key=operator.itemgetter(1), reverse=True)
b和c都能输出想要的结果,但是不太清楚这两种方法在运行机制和效率方面的区别,有谁可以解答下吗?
想要获得字典a中各科成绩的降序排名,代码如下。
a = {'math':98, 'english':100, 'PE':77}
b = sorted(a.iteritems(), key=operator.itemgetter(1), reverse=True)
c = sorted(a.items(), key=operator.itemgetter(1), reverse=True)
b和c都能输出想要的结果,但是不太清楚这两种方法在运行机制和效率方面的区别,有谁可以解答下吗?
4 回答4.4k 阅读✓ 已解决
1 回答3.1k 阅读✓ 已解决
4 回答3.8k 阅读✓ 已解决
3 回答2.1k 阅读✓ 已解决
1 回答4.4k 阅读✓ 已解决
1 回答3.9k 阅读✓ 已解决
1 回答2.8k 阅读✓ 已解决
itermitems()
返回的是一个能遍历所有键值对的生成器items()
返回的是整个列表中的键值对的拷贝,在你的dict比较大的情况下会消耗大量内存性能没比较过,你自己试试?
(我猜生成器性能更好)
python3里面的
items()
改成了iteritems()
的行为然后删除了iteritems()