Онлайн-курсы по Python
Выбрать другой урок из курса
Обсуждение
Теория урока

Словари в Python

В предыдущем уроке мы познакомились со списками в языке Python. Но они не всегда могут помочь. Например, когда у нас имеются данные в виде ключ/значение, удобнее использовать словари.

Словари в Python напоминают ассоциативные массивы. В них так же уникальному значению ключа соответствует произвольное значение. В языке С++ ему аналогичен контейнер map. Как объявить словарь в Python? Он объявляется в фигурных скобках:

Пример
person = {"firstname": "Ivan",
          "lastname": "Ivanov",
          "age": 30}

print(person["firstname"])           

Сначала записывается ключ, а затем, через двоеточие, указывается значение. И ключ, и значение могут быть любым объектом языка Python. Кстати, пары ключ/значение необязательно писать на разных строках:

Пример
person = {"firstname": "Ivan", "lastname": "Ivanov", "age": 30}           

Как видите, такой способ записи словаря менее читабельный.

Обратите внимание на обязательное разделение пар запятыми. Причем запятую после последней пары можно как ставить, так и опустить – интерпретатор Python ее проигнорирует.

Как вы помните, в списках элементы хранятся в порядке добавления. В свою очередь, словарь пренебрегает порядком хранения элементов.

Чтобы обратиться к элементу из списка, вам необходимо указать индекс элемента в квадратных скобках. В словаре, вместо индекса, задается ключ, например:

Пример
person["firstname"] # => Ivan           

Обращение по ключу позволяет быстро находить необходимую информацию, независимо от размера словаря. Это возможно благодаря хорошо оптимизированным алгоритмам.

Чтобы понять, как динамически добавлять элементы в словарь, рассмотрим следующий пример:

Пример
person = {"firstname": "Ivan",
          "lastname": "Ivanov",
          "age": 30,}
print(person)
person["id"] = 1;
print(person)           

Как видите, чтобы добавить новый элемент в словарь, необходимо в квадратных скобках указать ключ и присвоить ему значение.

Допустим, нам необходимо посчитать количество определенных букв в заданной фразе:

Пример
word = "словарь - это не список"
letters = {"а": 0, "е": 0, "и": 0, "о": 0}

for letter in word:
    if letter in letters:
        letters[letter] = letters[letter] + 1
    
print(letters)           

Сначала мы объявляем словарь, в котором инициализируем наши буквы (то есть присвоим ноль, чтобы избежать ошибок, о которых мы поговорим позже). Далее перебираем все буквы фразы, и если такая буква есть в нашем словаре, то увеличиваем ее значение на единицу. Но что если наш словарь пустой и нам необходимо подсчитать частоту каждого символа в строке? Если оставить все как есть, то наш код работать не будет. Чтобы это устранить, необходимо кое-что добавить:

Пример
word = "словарь - это не список"
letters = {}

for letter in word:
    if letter in letters:
        letters[letter] += 1
    else:
        letters[letter] = 1
    
print(letters)           

Мы добавили ветку else, которая будет выполняться, если ключа letter нет в словаре и заменили строку, в которой увеличивалось значение на эквивалентную. Давайте еще более упростим наш код, используя оператор not in:

Пример
for letter in word:
    if letter not in letters:
        letters[letter] = 0
    letters[letter] += 1           

И это еще не все. Для таких случаев был специально придуман метод setdefault:

Пример
for letter in word:
    letters.setdefault(letter, 0)
    letters[letter] += 1           

Из этого урока вы узнали, чем различаются словари и списки в Python, когда и что использовать. Так же вы познакомились с методом setdefault.

<
×
>
Не публикуйте свой код прямо в комментариях. Во-первых, он плохо отображается. Во-вторых, он может содержать для кого-то «спойлеры», т.е. ответы на практику. Воспользуйтесь специальными сервисами: cssdeck.com или jsfiddle.net.
Комментарии, содержащие код (пару строк не считается), будут безжалостно удаляться.