A sequence is any object or data structure which stores and accesses elements in a fixed order. Built-in sequence types include
range. By contrast, sets and dictionaries, while they share some common features with sequences, are not themselves sequences. Sequences always support iteration (though not all iterable types are necessarily sequences) and a set of other basic operations.
string is a sequence whose elements are characters (letters, symbols, or spaces) enclosed in quotation marks.
tuple is a sequence which stores elements of any type. Tuples are constructed by listing elements separated by commas, or by calling
tuple(s) for some sequence
list also stores elements of any type. Lists behave much like tuples, except lists are mutable (see below). Lists are constructed by enclosing elements in square brackets and separating them by commas, or by calling
list(s) for some sequence
The number of elements in a sequence
s is given by
Elements in a sequence are organized by index, an integer denoting where that element is located in the ordering. The first element is at index 0, the second and index 1, and so on. This convention is called zero-based indexing. Note that Python also allows negative indices for convenience. The last element is at -1, the second to last at -2, and so on.
A particular element
x in a sequence
s can be retrieved with <code">s[i]</code>, where
i is the index of
x. Note that this returns, but does not remove, the element
x. Negative indices are permissible.
Indices are also used to return a slice of the sequence. For a sequence
s, create a slice with the format
s[start:end:step]. This will return a subsequence which begins with the element at index
start, ends with the element at index
end - 1, counting indices by
step. If not specified
start defaults to 0,
end defaults to
step defaults to 1. Negative indices and steps (indicating counting indices backwards) are permissible. For example,
>>> s = "abababab" >>> s[:-2:2] "aaa"
Two sequences of the same type can be concatenated together with the addition operator, which returns a new sequence containing all the elements in the first sequence followed by all the elements in the second. For example,
(1, 2) + (3, 4) returns
(1, 2, 3, 4).
The only built-in mutable sequence type in Python is the
list. In addition to the common sequence operations, lists can support internal modification. For example,
>>> lst = [1, 2, 3] >>> lst = 5 >>> lst [5, 2, 3]
This piece of code creates
lst and replaces its first element. As opposed to concatenation and slicing, which leave the original unchanged and create new sequence objects with the specified modification, this changes the original list object itself.
Other operations which change the list object include
append, which takes in one argument and inserts that at the end of the list,
>>> lst.append(5) >>> lst [5, 2, 3, 5]
remove, which takes in one argument and removes the first instance of it from the list,
>>> lst.remove(5) >>> lst [2, 3, 5]
pop, which removes and returns the last element if it is not passed any additional arguments, or removes the element at index
i for integer
>>> lst.pop() 5 >>> lst [2, 3] >>> lst.pop(0) 2 >>> lst 
Other built-in methods which rely upon mutability include
sort which sorts the given list object in-place (without having to return a copy), and
reverse, which reverses a list object in-place.