使用python中的zip函数实现字典的排序

本文介绍了如何在Python中使用zip函数对字典的键值对进行排序,以便在保持分数排序的同时,能输出对应的学生名字。通过将字典的values和keys分别进行排序,然后使用zip进行组合,解决了当字典值相同时,按键排序的问题。这种方法在处理特定场景下可能存在的局限性也一并提出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:使用字典储存某个班级的单科成绩,并排序输出学生的名字和对应的分数。

分析:
用key存储名字,用value存储分数;
若是使用 sorted(dict) 的方法,其效果是对key(名字)排序;
若是使用 sorted( dict.values() ) 的方法,虽然对value(分数)进行了排序,但是无法输出分数对应的名字。

这里介绍一种利用zip函数来转换字典中的 key-value 的方法:

zip 内置函数:

	zip(iter1 [,iter2 [...]])
	
	返回一个zip对象,其内部方法__next__()返回一个元组;
	元组的第 i 个元素来自第 i 个可迭代参数;
	当某一个iter耗尽时,会触发 StopIteration 。

如:

arg_1 = ['A','B','C']
arg_2 = (1,2,3)
arg_3 = 'abc'

print(zip(arg_1,arg_2,arg_3))
print(list(zip(arg_1,arg_2,arg_3)))

终端输出:
<zip object at 0x000002A6B64C5888>
[('A', 1, 'a'), ('B', 2, 'b'), ('C', 3, 'c')]

#可以尝试修改 arg_3 = 'ab' ,再对比输出结果

了解zip用法后,可以使用 zip( d.values(), d.keys() ) 来得到 value-key 的元组。

class DictionarySorted:
    def __init__(self,dictionary):
        self.dictionary = dictionary

    def sort(self):
        return sorted(zip(self.dictionary.values(), self.dictionary.keys()))
        
if __name__ == "__main__":
    d = {'小明':88, '小铭':48, '小鸣':66}
    x = DictionarySorted(d)
    print(x.sort())

终端输出:
[(48, '小铭'), (66, '小鸣'), (88, '小明')]

不用类封装,用函数封装,代码如下:

def dict_sorted(dictionary):
	return sorted(zip(dictionary.values(), dictionary.keys()))
	
d = {'小明':88, '小铭':48, '小鸣':66}
print(dict_sorted(d))

上述方法存在一点不足,当存在同分的学生时,会依据key(名字)大小排序,如:

d = {'小明':88, '小铭':48, '小鸣':66,'b':60, 'a':60, 'c':60}
输出:
[(48, '小铭'), (60, 'a'), (60, 'b'), (60, 'c'), (66, '小鸣'), (88, '小明')]

这个缺陷虽然在该问题的环境下没什么影响,但是或许在别的环境下无法满足需求。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值