赞
踩
import operator # 导入operator 包,pip install operator
Departs = [] # 待排序列表
class Department: # 自定义的元素
def __init__(self, id, name, id2):
self.id = id
self.name = name
self.id2 = id2
# 创建元素和加入列表
Departs.append(Department(1, 'cbc', '1'))
Departs.append(Department(2, 'acd', '4'))
Departs.append(Department(3, 'bcd', '1'))
Departs.append(Department(1, 'bcd', '1'))
Departs.append(Department(2, 'acd', '3'))
# 划重点#划重点#划重点----排序操作
cmpfun = operator.attrgetter('id2') # 参数为排序依据的属性,可以有多个,这里优先id,使用时按需求改换参数即可
Departs.sort(key=cmpfun) # 使用时改变列表名即可
# 划重点#划重点#划重点----排序操作
# 此时Departs已经变成排好序的状态了,排序按照id优先,其次是name,遍历输出查看结果
for depart in Departs:
print(str(depart.id) + depart.name + depart.id2)
解释都在注释中,输出结果为:
可以看到
1.列表已经改变;
2.id和name都相同的两个部门的先后顺序未改变,说明该排序算法具有稳定性
一般性方法:
1.首先导入operator包,pip install operator
2.关键操作为定义cmpfun 和使用.sort,即:
cmpfun = operator.attrgetter(‘a’,‘b’) #这里是希望按照a,b两个属性排序,且优先按照a属性,使用时更换参数即可。
list.sort(key=cmpfun)#list为待排序列表
优先按照a属性,使用时更换参数即可。
list.sort(key=cmpfun)#list为待排序列表
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。