我正在研究一些元组的python字典。每个元组包含2个整数。元组中的第一个数字被认为是value,第二个数字被认为是work。我有3个不同的比较器,我需要按照降序对字典进行排序。这个顺序应该由调用哪个比较器决定。即字典可以按3种不同的方式分类。我尝试了尽可能多的不同方式,因为我可以找到这个工作。我可以在不使用比较器的情况下做到这一点,只需将其分解成列表并通过切分元组来排序即可,但如果任何人都可以通过比较器对语法进行排序,那么将不胜感激。我似乎正在为cmpWork正确地返回,但其他两个不会颠倒过来。
如果我能得到按元组值排序的字典,它也会很好。 我有一种与使用自定义比较器对元组的字典进行排序
sortedSubjects = sorted(tmpSubjects.iteritems(), key = operator.itemgetter(1), reverse = True)
工作,但这并不让我切片的元组。
第一次发布诺布如此道歉的任何错误。
def cmpValue(subInfo1, subInfo2):
return cmp(subInfo2[0] , subInfo1[0])
def cmpWork(subInfo1, subInfo2):
return cmp(subInfo1[1] , subInfo2[1])
def cmpRatio(subInfo1, subInfo2):
return cmp((float(subInfo2[0])/subInfo2[1]) , (float(subInfo1[0])/subInfo1[1]))
def greedyAdvisor(subjects, comparator):
tmpSubjects = subjects.copy()
sortedSubjects = sorted(tmpSubjects.values(), comparator, reverse = True)
print sortedSubjects
smallCatalog = {'6.00': (16, 8),'1.00': (7, 7),'6.01': (5, 3),'15.01': (9, 6)}
greedyAdvisor(smallCatalog, cmpRatio)
greedyAdvisor(smallCatalog, cmpValue)
greedyAdvisor(smallCatalog, cmpWork)
[(7, 7), (9, 6), (5, 3), (16, 8)]
[(5, 3), (7, 7), (9, 6), (16, 8)]
[(16, 8), (7, 7), (9, 6), (5, 3)]
PS
线
sortedSubjects = sorted(tmpSubjects.iteritems(), key = operator.itemgetter(1), reverse = True)
回报
[('6.00', (16, 8)), ('15.01', (9, 6)), ('1.00', (7, 7)), ('6.01', (5, 3))]
这几乎正是我要找的只是我不能排序在第二个值元组和我无法通过cmpRatio进行排序。
提示:'sorted'返回一个新列表;无需创建'tmpSubjects'。你可以直接返回'sorted'的结果 – 2013-04-10 13:53:31