Lists#

This page contains brief code snippets for list related operations. It is intended as a resource for quickly looking up the syntax for a particular task, most likely to jog a students memory.

While you may well learn something here, it is not written as a lesson.

Tip

You can modify and execute any of the code on this page.

  1. launch just click this icon at the top of the page

  2. live followed by this one

Table of Contents

Creating#

Bracket syntax#

Create an empty list using [ ]:

a_list  = []
print(a_list)
[]

Create a list of 3 None elements:

b_list  = [None] * 3
print(b_list)
[None, None, None]

Create a list with initial elements:

numbers = [0, 1, 2, 3, 4, 5]
print(numbers)
[0, 1, 2, 3, 4, 5]

list constructor#

Create an empty list using the list() constructor:

c_list  = list()
print(c_list)
[]

Create a list from another iterable:

letters = list("abcdefghijklmnopqrstuvwxyz")
print(letters)
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

Selecting Elements#

Elements are accessed via subscription with the syntax: COLLECTION[SELECTOR].

The SELECTOR can be:

Via index number#

First element:

print(letters[0])
a

Second element:

print(letters[1])
b

Last element:

print(letters[-1])
z

Via slice#

Or the SELECTOR can be a slice.

The syntax is either of the following.

  • COLLECTION[START:STOP]

  • COLLECTION[START:STOP:STEP]

From numbers[1] to before numbers[3]:

print(numbers[1:3])
[1, 2]

All but the first element:

print(numbers[1:])
[1, 2, 3, 4, 5]

All but the last element:

print(numbers[:-1])
[0, 1, 2, 3, 4]

Every other element from numbers[3] to before numbers[15]:

print(numbers[3:15:2])
[3, 5]

Elements in reversed order with a negative STEP number and a START that is greater than STOP.

print(numbers[2::-1])
print(numbers[-1:-3:-1])
[2, 1, 0]
[5, 4]

Entire list:

print(numbers[:])
[0, 1, 2, 3, 4, 5]

Exceptions#

An IndexError exception will be raised for any selectors using using non-existent index numbers.

value = numbers[10]
print(value)
---------------------------------------------------------------------------
IndexError                                Traceback (most recent call last)
Cell In[15], line 1
----> 1 value = numbers[10]
      2 print(value)

IndexError: list index out of range
value = numbers[-10]
print(value)
---------------------------------------------------------------------------
IndexError                                Traceback (most recent call last)
Cell In[16], line 1
----> 1 value = numbers[-10]
      2 print(value)

IndexError: list index out of range

Suppress errors with a try except block:

try:
  value = numbers[10]
except IndexError:
  value = None

print(value)
None

Modification#

Change#

By index#

numbers[1] = 100
print(numbers)
[0, 100, 2, 3, 4, 5]

By slice#

numbers[3:5] = [300, 400]
print(numbers)
[0, 100, 2, 300, 400, 5]

Add#

animals = ["bear", "chimpanzee", "elephant"]
print(animals)
['bear', 'chimpanzee', 'elephant']

To end#

animals.append("hedgehog")
print(animals)
['bear', 'chimpanzee', 'elephant', 'hedgehog']

At a specific position#

animals.insert(2, "dolphin")
print(animals)
['bear', 'chimpanzee', 'dolphin', 'elephant', 'hedgehog']
animals.insert(0, "antelope")
print(animals)
['antelope', 'bear', 'chimpanzee', 'dolphin', 'elephant', 'hedgehog']

From iterable#

Using .extend()#
from pprint import pprint

animals.extend(["lynx", "ocelot", "puma"])
pprint(animals)
['antelope',
 'bear',
 'chimpanzee',
 'dolphin',
 'elephant',
 'hedgehog',
 'lynx',
 'ocelot',
 'puma']
With concatenation#
animals = animals + ["skink", "turtle", "viper"]
pprint(animals)
['antelope',
 'bear',
 'chimpanzee',
 'dolphin',
 'elephant',
 'hedgehog',
 'lynx',
 'ocelot',
 'puma',
 'skink',
 'turtle',
 'viper']

Or using the += operator:

animals += ["wolf", "zebra"]
pprint(animals)
['antelope',
 'bear',
 'chimpanzee',
 'dolphin',
 'elephant',
 'hedgehog',
 'lynx',
 'ocelot',
 'puma',
 'skink',
 'turtle',
 'viper',
 'wolf',
 'zebra']
Repeatedly with multiplication#
steps = ["rinse", "repeat"]
print(steps)

steps = (steps * 3)
print(steps)
['rinse', 'repeat']
['rinse', 'repeat', 'rinse', 'repeat', 'rinse', 'repeat']

Or using the *= operator:

steps = ["rinse", "repeat"]
print(steps)

steps *= 3
print(steps)
['rinse', 'repeat']
['rinse', 'repeat', 'rinse', 'repeat', 'rinse', 'repeat']

Remove#

chars = list("Hello world")

del chars[4]
print(chars)
['H', 'e', 'l', 'l', ' ', 'w', 'o', 'r', 'l', 'd']

By index#

chars = list("Hello world")

del chars[4]
print(chars)
['H', 'e', 'l', 'l', ' ', 'w', 'o', 'r', 'l', 'd']

By value#

Remove first occurrence of value using the .remove() method:

chars = list("Hello world")

chars.remove("l")
print(chars)
['H', 'e', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

By slice#

Using the del keyword:

chars = list("Hello world")

del chars[2:9]
print(chars)
['H', 'e', 'l', 'd']

By assigning to an empty list:

chars = list("Hello world")

chars[0:3] = []
print(chars)
['l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

All elements#

chars = list("Hello world")

chars.clear()
print(chars)
[]

Remove and return#

The last element#
chars = list("Hello world")

removed = chars.pop()

print("removed:", repr(removed), "\n")
print(chars)
removed: 'd' 

['H', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l']
A specific element by position#
chars = list("Hello world")

removed = chars.pop(2)

print("removed:", repr(removed), "\n")
print(chars)
removed: 'l' 

['H', 'e', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']

Membership#

chars = list("Mississippi")
words = ['Welcome', 'to', 'Python', 'Class']

Contains#

Check if list contains value using the in operator:

"Class" in words
True

Check if list does not contains value using the not in operator:

"Class" not in words
False

Count#

Number of times value occurs in list:

chars.count("i")
4

Index#

To look up the index number of a particular value, use the .index() method.

Get the first index number of value:

chars.index("s")
2

Same, but look in chars[3:]:

chars.index("s", 3)
3

Same, but look in chars[5:9]:

chars.index("i", 5, 9)
7

Iteration#

for loop#

Iterate over each element:

colors = ["red", "blue", "green"]
for item in colors:
  print(item)
red
blue
green

enumerate#

Iterate over each index number and element:

meals = ["breakfast", "lunch", "dinner"]
for i, item in enumerate(meals):
  print(i, item)
0 breakfast
1 lunch
2 dinner

Iterate over each index number and element value, starting i at 1:

drinks = ["water", "tea", "coffee"]
for i, item in enumerate(drinks, 1):
  print(i, item)
1 water
2 tea
3 coffee

Aggregation#

Functions that provide information about the container as a whole.

Length#

len([0, 1, 2, 3])
4

Maximum value#

max([0, 1, 2, 3])
3

Minimum value#

min([0, 1, 2, 3])
0

Sum of values#

sum([0, 1, 2, 3])
6

any#

Return True if any elements are truthy:

any([0, False, ""])
False
any([0, 1, 2, 3])
True

all#

Return True if all elements are truthy:

all([0, 1, 2, 3])
False
all([True, 1, "hello"])
True

Copying#

DEFAULTS = [
  {
    'name': "Joe Smith",
    'email': 'joe.smith@gmail.com',
  },
  {
    'name': "Jane Doe",
    'email': "jane.doe@gmail.com"
  }
]

Alias#

A reference or alias creates a new variable that points to the same object.

authors = DEFAULTS

authors is DEFAULTS
True

Shallow copy#

A shallow copy creates a new container object then adds references to elements.

Using .copy():

authors = DEFAULTS.copy()

print(authors is DEFAULTS)
print(authors[0] is DEFAULTS[0])
False
True

Using copy.copy():

import copy

authors = copy.copy(DEFAULTS)

print(authors is DEFAULTS)
print(authors[0] is DEFAULTS[0])
False
True

Using a slice:

authors = DEFAULTS[:]

print(authors is DEFAULTS)
print(authors[0] is DEFAULTS[0])
False
True

Deep copy#

A deep copy creates a new container object then recursively adds the copies of nested elements.

import copy
authors = copy.deepcopy(DEFAULTS)

print(authors is DEFAULTS)
print(authors[0] is DEFAULTS[0])
False
False

Sorting#

"""setup for sorting section"""

# define global FRUIT list
FRUIT = ["cherry", "apple", "date", "bananna", "elderberry"]

Returned sorting#

The following functions return a sorted version of the collection and leave original collection unmodified.

# copy fruit list
fruit = FRUIT[:]
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']

Ascending order#

result = sorted(fruit)
pprint(result)
['apple',
 'bananna',
 'cherry',
 'date',
 'elderberry']

Descending order#

result = sorted(fruit, reverse=True)
pprint(result)
['elderberry',
 'date',
 'cherry',
 'bananna',
 'apple']

Reverse order#

result = list(reversed(fruit))
pprint(result)
['elderberry',
 'bananna',
 'date',
 'apple',
 'cherry']

Order by callable key#

Using function:

def order_by_length(text):
    return len(text)

result = sorted(fruit, key=order_by_length)
pprint(result)
['date',
 'apple',
 'cherry',
 'bananna',
 'elderberry']

Using lambda:

result = sorted(fruit, key=lambda v: len(v))
pprint(result)
['date',
 'apple',
 'cherry',
 'bananna',
 'elderberry']

In-place sorting#

The following methods and functions change the order of the original collection and return None.

Ascending order#

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

fruit.sort()
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['apple',
 'bananna',
 'cherry',
 'date',
 'elderberry']

Descending order#

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

fruit.sort(reverse=True)
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['elderberry',
 'date',
 'cherry',
 'bananna',
 'apple']

Reverse order#

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

fruit.reverse()
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['elderberry',
 'bananna',
 'date',
 'apple',
 'cherry']

Order by callable key function#

Using function:

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

def order_by_length(text):
    return len(text)

fruit.sort(key=order_by_length)
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['date',
 'apple',
 'cherry',
 'bananna',
 'elderberry']

Using lambda:

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

fruit.sort(key=lambda v:len(v))
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['date',
 'apple',
 'cherry',
 'bananna',
 'elderberry']

Random order#

# reset fruit list
fruit = FRUIT[:]
pprint(fruit)
print("--------------")

from random import shuffle
shuffle(fruit)
pprint(fruit)
['cherry',
 'apple',
 'date',
 'bananna',
 'elderberry']
--------------
['elderberry',
 'cherry',
 'bananna',
 'date',
 'apple']

Transformation#

Generate a modified collection.

Mapping#

Produce a new collection containing the results from applying a function to each element in a collection.

"""Setup for the Mapping section"""

# the collection to base mappings on
birth_years = [1954, 1956, 1984, 1986]

# used in relative_age()
REL_YEAR = 1994

# the function to apply
def relative_age(year):
  return REL_YEAR - year

Using a for loop#

# initialize a list the same size as birth_years filled with None values
ages = [None] * len(birth_years)

# iterate over birth years and map the cooresponding element in ages to
# the results from applying the function to that element
for i, year in enumerate(birth_years):
  ages[i] = relative_age(year)

# print the ages list
print(ages)
[40, 38, 10, 8]

Using list comprehension#

ages = [relative_age(year) for year in birth_years]

print(ages)
[40, 38, 10, 8]

Using map#

ages = list(map(relative_age, birth_years))

print(ages)
[40, 38, 10, 8]

Filtering#

Produce a new collection containing only elements which, when a applying a function, return a truthy value.

"""Setup for the Filtering section"""

# the function to apply
def is_adult(age):
  return age >= 18

# print the previously created ages collection to base the filterings on
print(ages)
[40, 38, 10, 8]

Using a for loop#

# initialze an empty list
adults = []

# iterate over ages and append elements that results in True
# when applying the filtering function
for age in ages:
  if is_adult(age):
    adults.append(age)

# print the adults list
print(adults)
[40, 38]

Using list comprehension#

adults = [ age for age in ages if is_adult(age) ]

print(adults)
[40, 38]

Using filter#

adults = list(filter(is_adult, ages))

print(adults)
[40, 38]

Typecasting#

str to list#

individual characters#

list("abc")
['a', 'b', 'c']

split on whitespace#

"list info search".split()
['list', 'info', 'search']

split on delimiter#

"555-555-5555".split("-")
['555', '555', '5555']

split on newlines#

"a\nb\nc\n".splitlines()
['a', 'b', 'c']

split on pattern#

import re
re.split(r"[./]", "github.com/git")
['github', 'com', 'git']

dict to list#

fruit_sizes = {'cherry': 6, 'bananna': 7, 'date': 4, 'elderberry': 10, 'apple': 5}

keys#

list(fruit_sizes)
['cherry', 'bananna', 'date', 'elderberry', 'apple']
list(fruit_sizes.keys())
['cherry', 'bananna', 'date', 'elderberry', 'apple']

values#

list(fruit_sizes.values())
[6, 7, 4, 10, 5]

list to string#

"".join(["a", "b", "c"])
'abc'

list to dict#

dict([["a", 1], ["b", 2]])
{'a': 1, 'b': 2}
dict(zip(["a", "b"], [1, 2]))
{'a': 1, 'b': 2}