Jak w Pythonie przenieść element do określonego indeksu na liście?
Jak w Pythonie przenieść element do określonego indeksu na liście?
Odpowiedzi:
Użyj insertmetody listy:
l = list(...)
l.insert(index, item)
Alternatywnie możesz użyć notacji plasterków:
l[index:index] = [item]
Jeśli chcesz przenieść element, który jest już na liście do określonej pozycji, musisz go usunąć i wstawić w nowym miejscu:
l.insert(newindex, l.pop(oldindex))
last index + 1bez błędów. W takim przypadku element jest po prostu dodawany do listy.
a.insert(99999, 1) In [14]: a Out[14]: [...., 1]
Nieco krótsze rozwiązanie, które tylko przenosi element na koniec, nigdzie nie jest to:
l += [l.pop(0)]
Na przykład:
>>> l = [1,2,3,4,5]
>>> l += [l.pop(0)]
>>> l
[2, 3, 4, 5, 1]
l.append(l.pop(0)). Jest tylko nieznacznie dłuższy, ale jest znacznie bardziej czytelny.
Jeśli nie znasz pozycji elementu, może być konieczne znalezienie najpierw indeksu:
old_index = list1.index(item)
następnie przesuń go:
list1.insert(new_index, list1.pop(old_index))
lub IMHO czystszy sposób:
try:
list1.remove(item)
list1.insert(new_index, item)
except ValueError:
pass
passoświadczenia ... nigdy nie ukrywaj wyjątków - domyślną rzeczą w takim przykładzie powinno być podanie bardziej przejrzystego komunikatu błędu lub wypisania instrukcji ... raise ValueError(f'Unable to move item to {new_index}')lub print(f'Moving item to {new_index} failed. List remains unchanged.'). Może passbyłoby w porządku, gdyby funkcja została wywołana try_to_move_itemlub coś, co zrozumiałoby, że operacja może się nie powieść po cichu.
Rozwiązanie bardzo proste, ale musisz znać indeks pierwotnej pozycji i indeks nowej pozycji:
list1[index1],list1[index2]=list1[index2],list1[index1]
Wyprofilowałem kilka metod przenoszenia elementu na tej samej liście z czasem. Oto te, których należy użyć, jeśli j> i:
┌──────────┬──────────────────────┐ │ 14,4usec │ x [i: i] = x.pop (j), │ │ 14,5usec │ x [i: i] = [x.pop (j)] │ │ 15,2usec │ x.insert (i, x.pop (j)) │ └──────────┴──────────────────────┘
a tutaj te, których należy użyć, jeśli j <= i:
┌──────────┬───────────────────────────┐ │ 14,4 usec │ x [i: i] = x [j] ,; del x [j] │ │ 14,4 usec │ x [i: i] = [x [j]]; del x [j] │ │ 15,4 usec │ x.insert (i, x [j]); del x [j] │ └──────────┴───────────────────────────┘
Nie jest to duża różnica, jeśli używasz go tylko kilka razy, ale jeśli robisz ciężkie rzeczy, takie jak ręczne sortowanie, ważne jest, aby wybrać najszybszy. W przeciwnym razie radziłbym po prostu wziąć ten, który uważasz za najbardziej czytelny.