整理出最高编号显示的内容

时间:2015-09-12 03:16:31

标签: python for-loop find-occurrences

我有以下图片:请查看以供参考。

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

1 个答案:

答案 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):