将显示的内容按最高数排序
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):
我有下图:请看一下参考。
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):