Python Language
Listenaufteilung (Auswählen von Listenteilen)
Suche…
Syntax
- a [start: end] # Elemente beginnen bis Ende-1
- a [start:] # Elemente beginnen durch den Rest des Arrays
- a [: end] # Elemente vom Anfang bis Ende-1
- a [start: end: step] # Schritt für Schritt nicht vorbei
- a [:] # eine Kopie des gesamten Arrays
- Quelle
Bemerkungen
-
lst[::-1]
Sie eine umgekehrte Kopie der Liste -
start
oderend
kann eine negative Zahl sein, dh sie zählt vom Ende des Arrays statt vom Anfang. So:
a[-1] # last item in the array
a[-2:] # last two items in the array
a[:-2] # everything except the last two items
( Quelle )
Verwenden Sie das dritte Argument "step"
lst = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h']
lst[::2]
# Output: ['a', 'c', 'e', 'g']
lst[::3]
# Output: ['a', 'd', 'g']
Auswahl einer Unterliste aus einer Liste
lst = ['a', 'b', 'c', 'd', 'e']
lst[2:4]
# Output: ['c', 'd']
lst[2:]
# Output: ['c', 'd', 'e']
lst[:4]
# Output: ['a', 'b', 'c', 'd']
Umkehren einer Liste mit dem Schneiden
a = [1, 2, 3, 4, 5]
# steps through the list backwards (step=-1)
b = a[::-1]
# built-in list method to reverse 'a'
a.reverse()
if a = b:
print(True)
print(b)
# Output:
# True
# [5, 4, 3, 2, 1]
Verschieben einer Liste mit dem Schneiden
def shift_list(array, s):
"""Shifts the elements of a list to the left or right.
Args:
array - the list to shift
s - the amount to shift the list ('+': right-shift, '-': left-shift)
Returns:
shifted_array - the shifted list
"""
# calculate actual shift amount (e.g., 11 --> 1 if length of the array is 5)
s %= len(array)
# reverse the shift direction to be more intuitive
s *= -1
# shift array with list slicing
shifted_array = array[s:] + array[:s]
return shifted_array
my_array = [1, 2, 3, 4, 5]
# negative numbers
shift_list(my_array, -7)
>>> [3, 4, 5, 1, 2]
# no shift on numbers equal to the size of the array
shift_list(my_array, 5)
>>> [1, 2, 3, 4, 5]
# works on positive numbers
shift_list(my_array, 3)
>>> [3, 4, 5, 1, 2]
Modified text is an extract of the original Stack Overflow Documentation
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow