将显示的内容按最高数排序

Sort out the content displayed by the highest number

我有下图:请看一下参考。

http://i58.tinypic.com/33219hh.png

这是我的代码:

import xlrd,xlwt

def printDate(res):
    for k,v in sorted(res.items(),key = lambda (k,v):(v,k),reverse= True):
        print('{} : {}'.format(k,v))
    print()

location = 'C:\Users\Jack\Desktop\'
workbk = xlrd.open_workbook(location + 'Try.xlsx')
sht = workbk.sheet_by_index(0)
letterRes, numRes = {},{}
for a in range(1,sht.nrows):
    numValue = sht.cell(a,0).value
    letterValue = sht.cell(a,1).value
    numRes[numValue] = numRes.get(numValue,0) + 1
    letterRes[letterValue] = letterRes.get(letterValue,0) + 1

printDate(letterRes)
printDate(numRes)

此代码应打印出 "Numbers" 和 "Letters" 列,并告诉我每个数字或字母在该列中出现了多少次。换句话说,该数字或字母出现的次数。

输出应该是:

B : 4
E : 3
D : 3
A : 3
C : 1

3.0 : 4
5.0 : 3
4.0 : 3
2.0 : 2
1.0 : 2

它给我以下错误:

File "<ipython-input-27-6fe05dd3daca>", line 6
    for x,y in sorted(res.items(),key = lambda (x,y):(y,x),reverse= True):
                                               ^
SyntaxError: invalid syntax

您不能在 Python 3.x -

中执行以下操作
lambda (k,v):(v,k)

以上只在Python 2.x有效。例子-

>>> lambda (k,v):(v,k)
  File "<stdin>", line 1
    lambda (k,v):(v,k)
           ^
SyntaxError: invalid syntax

您应该获取单个元素,然后使用下标按索引访问该元素。例子-

for k,v in sorted(res.items(),key = lambda x:(x[1],x[0]),reverse= True):