Containers, basic operations on

Abjad containers work like Python lists.


Container properties

The length of a container is defined equal to the number of components in the container:

>>> container = abjad.Container("ds'16 cs'16 e'16 c'16 d'2 ~ d'8")
>>> abjad.show(container)
>>> len(container)
6

Iteration

Containers iterate their contents like lists:

>>> for item in container:
...     item
... 
Note("ds'16")
Note("cs'16")
Note("e'16")
Note("c'16")
Note("d'2")
Note("d'8")

Item getting

Item getting returns one component at a time:

>>> container[0]
Note("ds'16")
>>> container[1]
Note("cs'16")
>>> container[2]
Note("e'16")

Slicing returns a selection of components:

>>> container[:3]
[Note("ds'16"), Note("cs'16"), Note("e'16")]

Containment testing

Containment testing and indexing work like lists:

>>> note = container[0]
>>> note in container
True
>>> container.index(note)
0
>>> rest = abjad.Rest("r4")
>>> rest in container
False

Adding components

Append, extend and insert work like lists:

>>> container.append("af'32")
>>> abjad.show(container)
>>> container.extend("c''32 a'32")
>>> abjad.show(container)
>>> container.insert(-3, "g'32")
>>> abjad.show(container)

Removing components

And pop and remove work like lists, too:

>>> note = container.pop(-1)
>>> abjad.show(container)
>>> note = container[-1]
>>> container.remove(note)
>>> abjad.show(container)