Codebra
29 января 2026 в 18:31

Урок 22. Словари в Python

Как создать словарь в Python. Какие методы необходимо знать. Метод setdefault.
📝

Внимание! На этой странице вы найдете материал урока из архивного курса по Python. Курс был написан в 2024 году и по-прежнему актуален для начинающих разработчиков.

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

Полный список уроков доступен по тегу Архивный курс по Python и на странице первого урока.

📝 Кратко
  • Словари в Python напоминают ассоциативные массивы и аналогичны контейнеру map в С++.
  • Словарь объявляется в фигурных скобках с указанием ключа и значения через двоеточие.
  • Ключ и значение могут быть любым объектом Python.
  • Обращение к элементу словаря осуществляется по ключу, а не индексу.
  • Динамическое добавление элементов в словарь осуществляется через метод setdefault().
  • Метод setdefault() позволяет избежать ошибок при подсчете частоты символов в строке.

В предыдущих уроках мы познакомились со списками и операциями над ними (Урок 18. Списки в Python, Урок 19. Изменение списка на месте (срезы) в Python, Урок 20. Дополнительно про списки в Python, Урок 21. Конкатенация и сортировка списков в 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().

В следующем уроке познакомимся с другим способом создания словарей и списков в Python.

📝

Переходите к следующему уроку курса, а так же не забудьте посмотреть новый материал на Codebra по тегу Python.