我有以下图片:请查看以供参考。
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"和#34;信件"列,并告诉我列中每个数字或字母出现的次数。换句话说,该数字或字母的出现次数。
输出应为:
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
答案 0 :(得分:1)
您无法在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):