我有以下图片:请查看以供引用。
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)
这段代码应该打印出“数字”和“字母”列,并告诉我每个数字或字母在该列中出现了多少次。换句话说,该数字或字母出现的次数。
输出应该是:
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):
关于python - 按数字最大的顺序对显示的内容进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32534822/