wie ein dict Stellen Sie sich vor, so (Abbildung von a-z
mit a = 1 und z = 26):
>>> d={k:v for k,v in zip((chr(i+97) for i in range(26)),range(1,27))}
>>> d
{'g': 7, 'f': 6, 'e': 5, 'd': 4, 'c': 3, 'b': 2, 'a': 1, 'o': 15, 'n': 14, 'm': 13, 'l': 12, 'k': 11, 'j': 10, 'i': 9, 'h': 8, 'w': 23, 'v': 22, 'u': 21, 't': 20, 's': 19, 'r': 18, 'q': 17, 'p': 16, 'z': 26, 'y': 25, 'x': 24}
Jetzt können Sie dies tun:
>>> v=list(d.values())
>>> k=list(d.keys())
>>> [k[v.index(i)] for i in sorted(d.values(),reverse=True)[0:10]]
['z', 'y', 'x', 'w', 'v', 'u', 't', 's', 'r', 'q']
Sie erklärte auch, dass einige Werte von Das Mapping wird gleich sein. Nun ist d
lassen aktualisieren, damit es die Buchstaben A-Z
mit dem Mapping hat 1-26:
>>> d.update({k:v for k,v in zip((chr(i+65) for i in range(26)),range(1,27))})
jetzt beide A-Z
und a-z
Karte zu 1-26
:
>>> d
{'G': 7, 'F': 6, 'E': 5, 'D': 4, 'C': 3, 'B': 2, 'A': 1, 'O': 15, 'N': 14, 'M': 13, 'L': 12, 'K': 11, 'J': 10, 'I': 9, 'H': 8, 'W': 23, 'V': 22, 'U': 21, 'T': 20, 'S': 19, 'R': 18, 'Q': 17, 'P': 16, 'Z': 26, 'Y': 25, 'X': 24, 'g': 7, 'f': 6, 'e': 5, 'd': 4, 'c': 3, 'b': 2, 'a': 1, 'o': 15, 'n': 14, 'm': 13, 'l': 12, 'k': 11, 'j': 10, 'i': 9, 'h': 8, 'w': 23, 'v': 22, 'u': 21, 't': 20, 's': 19, 'r': 18, 'q': 17, 'p': 16, 'z': 26, 'y': 25, 'x': 24}
So mit doppelten Zuordnungen, die einzig sinnvolle Ergebnis ist eine Liste der Schlüssel zurückzugeben, die den Wert haben:
>>> [[k[x] for x,z in enumerate(v) if z==i ] for i in sorted(d.values(),reverse=True)[0:10]]
[['Z', 'z'], ['Z', 'z'], ['Y', 'y'], ['Y', 'y'], ['X', 'x'], ['X', 'x'], ['W', 'w'], ['W', 'w'], ['V', 'v'], ['V', 'v']]
Und Sie heapq hier nutzen könnten:
[[k[x] for x,z in enumerate(v) if z==i ] for i in heapq.nlargest(10,v)]
Du hast nicht sagen, was Sie mit den doppelten Ergebnissen tun möchte, so nehme ich an Sie, diese Duplikate eliminiert wollen würde, während die Ergebnisliste N lange bleiben.
Dies tut das:
def topn(d,n):
res=[]
v=d.values()
k=d.keys()
sl=[[k[x] for x,z in enumerate(v) if z==i] for i in sorted(v)]
while len(res)<n and sl:
e=sl.pop()
if e not in res:
res.append(e)
return res
>>> d={k:v for k,v in zip((chr(i+97) for i in range(26)),range(1,27))}
>>> d.update({k:v for k,v in zip((chr(i+65) for i in range(0,26,2)),range(1,27,2))})
>>> topn(d,10)
[['z'], ['Y', 'y'], ['x'], ['W', 'w'], ['v'], ['U', 'u'], ['t'], ['S', 's'], ['r'], ['Q', 'q']]
Bedeutet "Top 10 Elemente" die größten 10 Werte? – dawg
Ja, das bedeutet größte Werte – gizgok
Wie sollen die Duplikate behandelt werden? Ich meine, sollten wir sie einfach ignorieren, als ob sie unterschiedliche Werte wären, oder sollten wir nur einen der duplizierten Werte behalten? – Bakuriu