Ich versuche ordentlich pythonic Möglichkeiten zu lernen, Dinge zu tun, und frage mich, warum meine for-Schleife kann nicht auf diese Weise Refactoring:Inline for-Schleife
q = [1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5]
vm = [-1, -1, -1, -1]
for v in vm:
if v in q:
p.append(q.index(v))
else:
p.append(99999)
vm[p.index(max(p))] = i
Ich habe versucht, mit der for-Schleife zu ersetzen:
[p.append(q.index(v)) if v in q else p.append(99999) for v in vm]
Aber es funktioniert nicht. Die for v in vm:
Schleife entfernt Nummern von vm
basierend auf, wenn sie als nächstes in q
kommen.
Möglicherweise möchten Sie verwenden - 1 anstelle von 99999 für eine Markierung eines nicht vorhandenen Wertes (so würde es sogar für eine Liste mit 99999+ Elementen funktionieren) –
Sie Listenkomprehension wird funktionieren, aber es wird Listen von Keine zurückgeben – Hackaholic
Ich habe 99999 anstelle von -1 verwendet, weil später ich lief a max (p) und nicht vorhandene Werte müssen ausgewählt werden. – Will