在Python中添加具有排序顺序的附加列

时间:2017-04-26 14:21:00

标签: python sorting dictionary ranking information-retrieval

我有以下代码:

ID= # type is <class 'str'>
dictionary={} #Dictionary

 with open('result.PRED', 'a') as fileOut:
        for item in dictionary.keys():
            print(Question_ID,item,dictionary[item],sep='\t',file=fileOut)

从我的文档排名模型生成以下结果:

Q1_R1   Q1_R1_C1    0.0
Q1_R1   Q1_R1_C10   0.0
Q1_R1   Q1_R1_C2    0.0
Q1_R1   Q1_R1_C3    0.196116135138
Q1_R1   Q1_R1_C4    0.353553390593
Q1_R1   Q1_R1_C5    0.205267008777
Q1_R1   Q1_R1_C6    0.408248290464
Q1_R1   Q1_R1_C7    0.0
Q1_R1   Q1_R1_C8    0.0
Q1_R1   Q1_R1_C9    0.0
Q1_R6   Q1_R6_C1    0.301637573861
Q1_R6   Q1_R6_C10   0.199260956948
Q1_R6   Q1_R6_C2    0.147292928305
Q1_R6   Q1_R6_C3    0.0860264946736
Q1_R6   Q1_R6_C4    0.0819313340205
Q1_R6   Q1_R6_C5    0.244377512197
Q1_R6   Q1_R6_C6    0.161126919432
Q1_R6   Q1_R6_C7    0.152303771019
Q1_R6   Q1_R6_C8    0.0
Q1_R6   Q1_R6_C9    0.0

我需要创建一个额外的列,该列是基于第3列中给出的分数的排名。此外,第二列未正确排序,因为C10出现在C2之前。

例如,我想尝试如下;

Q1_R1   Q1_R1_C1    0.0    4
Q1_R1   Q1_R1_C2    0.0    5
Q1_R1   Q1_R1_C3    0.196116135138    3
Q1_R1   Q1_R1_C4    0.353553390593    1
Q1_R1   Q1_R1_C5    0.205267008777    2
.....    .....    ....  ....
Q1_R1   Q1_R1_C10   0.0    6

我已经用各种方式尝试了很长时间,我找不到办法处理这个问题。谢谢

1 个答案:

答案 0 :(得分:1)

我使用输出字符串作为输入数据,使用split()方法获取列表并按第三项排序,然后再按多个键对列表进行排序,这里是代码:

r="""Q1_R1 Q1_R1_C1 0.0
Q1_R1 Q1_R1_C10 0.0
...
Q1_R6 Q1_R6_C6 0.161126919432
Q1_R6 Q1_R6_C7 0.152303771019
Q1_R6 Q1_R6_C8 0.0
Q1_R6 Q1_R6_C9 0.0"""

l=[i.split(' ') for i in r.split('\n')]
tmp=sorted(l,key=lambda x:float(x[2]),reverse=True)

for i in sorted([j+[i+1] for i,j in enumerate(tmp)],key=lambda x:(x[0],int(x[1].split('C')[-1]))):
    print("\t".join(map(str,i)))

结果:

Q1_R1   Q1_R1_C1    0.0 13
Q1_R1   Q1_R1_C2    0.0 15
Q1_R1   Q1_R1_C3    0.196116135138  7
Q1_R1   Q1_R1_C4    0.353553390593  2
Q1_R1   Q1_R1_C5    0.205267008777  5
Q1_R1   Q1_R1_C6    0.408248290464  1
Q1_R1   Q1_R1_C7    0.0 16
Q1_R1   Q1_R1_C8    0.0 17
Q1_R1   Q1_R1_C9    0.0 18
Q1_R1   Q1_R1_C10   0.0 14
Q1_R6   Q1_R6_C1    0.301637573861  3
Q1_R6   Q1_R6_C2    0.147292928305  10
Q1_R6   Q1_R6_C3    0.0860264946736 11
Q1_R6   Q1_R6_C4    0.0819313340205 12
Q1_R6   Q1_R6_C5    0.244377512197  4
Q1_R6   Q1_R6_C6    0.161126919432  8
Q1_R6   Q1_R6_C7    0.152303771019  9
Q1_R6   Q1_R6_C8    0.0 19
Q1_R6   Q1_R6_C9    0.0 20
Q1_R6   Q1_R6_C10   0.199260956948  6