Как вывести ключ словаря?

Мне нужно вывести на экран ключ словаря, соответствующий элементу списка, который есть в словаре.
Отслеживать
48.6k 17 17 золотых знаков 56 56 серебряных знаков 100 100 бронзовых знаков
задан 10 мая 2020 в 7:37
POLTERGEIST POLTERGEIST
13 5 5 бронзовых знаков
Обычно словарь используют наоборот. По ключу ищут элемент. В этом его смысл. Может, вам просто поменять местами ключи и значения?
10 мая 2020 в 7:45
Я пробовал, а результат такой же был, я поэтому решил попробовать поменять местами
10 мая 2020 в 7:46
@POLTERGEIST, можно попробовать записывать два значения разом. Первое например ‘Питон’ : ‘Python’ , а второе ‘Python’ : ‘Питон’
10 мая 2020 в 8:57
2 ответа 2
Сортировка: Сброс на вариант по умолчанию
Возможно, это решит ваш вопрос.
Когда в словаре находится ключ/значение, соответствующее искомому, возвращается пара ключ, значение в виде кортежа
>>> a = >>> def search(d: dict, key): . lst = zip(a.keys(), a.values()) . for k, v in lst: . if key in (k, v): . return k, v . >>> search(a, None) ('5', None) >>> search(a, '3') ('3', 4)
Отслеживать
ответ дан 10 мая 2020 в 10:27
4,507 2 2 золотых знака 9 9 серебряных знаков 28 28 бронзовых знаков
Вместо lst = zip(a.keys(), a.values()) можно написать просто lst = a.items()
14 мая 2020 в 13:01
@insolor спасибо, буду знать =)
14 мая 2020 в 13:27
a = def search(a, b): c = list(a.values()).index(b) return list(a.keys())[c] print(search(a, 100))
Отслеживать
ответ дан 14 мая 2020 в 12:09
user388629 user388629
-
Важное на Мете
Похожие
Подписаться на ленту
Лента вопроса
Для подписки на ленту скопируйте и вставьте эту ссылку в вашу программу для чтения RSS.
Дизайн сайта / логотип © 2024 Stack Exchange Inc; пользовательские материалы лицензированы в соответствии с CC BY-SA . rev 2024.1.3.2953
Нажимая «Принять все файлы cookie» вы соглашаетесь, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.
Вызов значений из словаря Python: методы .get() и .setdefault() вместо квадратных скобок
Вы всё ещё пользуетесь квадратными скобками? Тогда мы идём к вам.


Dana Moskvina / Skillbox Media

Цокто Жигмытов
Кандидат философских наук, специалист по математическому моделированию. Пишет про Data Science, AI и программирование на Python.
Словарь в Python — это набор из пар «ключ: значение». Основные его свойства:
- В каждой паре ключ (key) указывает на значение (value).
- Ключи уникальны, повторов нет. Значения могут быть одинаковыми.
- В отличие от списка или кортежа, словарь не упорядочен, то есть нельзя указать, какая пара в нём идёт первой, а какая последней.
Ключ от значения отделяется двоеточием, а пары разделяются запятыми. Весь словарь заключён в фигурные скобки <>.

Обычный (не слишком хороший) способ
Первый способ, который узнают начинающие питонисты, — это вызов значений с помощью квадратных скобок. Пишется имя словаря, а за ним в квадратных скобках идёт ключ. Если Python находит такой ключ в словаре, то возвращает соответствующее ему значение.
author = < "first_name": "Виктор", "last_name": "Пелевин", "username": "dao1962" > author['username'] >>> 'dao1962' author['age'] >>> Traceback (most recent call last): File "", line 1, in module> author['age'] KeyError: 'age'
Если же такого ключа нет, то вернётся исключение KeyError. И это, надо сказать, довольно неприятно, особенно в случае с объёмными и часто изменяющимися данными.
Путей решения этой проблемы несколько:
- Использовать конструкцию try / except (схожую с условным оператором if / else), которая будет обрабатывать KeyError и возвращать не само исключение, а что-то более удобное для работы — например, сообщение.
try: author['age'] except KeyError: print('Такого ключа нет') >>> 'Такого ключа нет'
- Использовать встроенную библиотеку collections, а конкретно структуру defaultdict из неё — расширение над обычным словарём, позволяющее устанавливать значения по умолчанию для запрошенных несуществующих ключей.
Но есть и третий способ, даже два. Словарь в Python поддерживает встроенные методы вызова значения .get() и .setdefault(), которые позволяют обойтись без обработки исключений и импорта библиотек. Их мы и рассмотрим.
Вызов с помощью .get()
Пожалуй, самый безопасный способ вызова значений из словаря. У него два параметра:
- Первый (обязательный) — ключ, значение которого мы хотим вызвать.
- Второй (опциональный) — значение, которое вернёт метод, если ключа в словаре не существует. По умолчанию оно равно None — его метод и вернёт.
author.get('first_name') >>> 'Виктор' author.get('age') # ничего не происходит print(author.get('age')) # поэтому используем print >>> None author.get('age', 'Такого ключа в словаре нет') >>> 'Такого ключа в словаре нет'
Если ключ в словаре существует, то вызов .get() ничем не отличается от вызова с помощью квадратных скобок. Если же ключа нет, то метод возвращает второй параметр — либо None, либо, например, строку с сообщением.
И не надо обрабатывать ошибки и исключения.
Вызов с помощью .setdefault()
Иногда может понадобиться не только защита от ошибки KeyError, но и исправление самого словаря. Для этого применяется метод .setdefault(), который по синтаксису и выводу похож на .get() и принимает те же два параметра: вызываемый ключ и его значение по умолчанию.
Обнаружив, что вызываемого ключа не существует, метод .setdefault():
- сам создаёт ключ;
- создаёт к нему в пару значение, заданное вами (по умолчанию — None);
- добавляет получившуюся пару в словарь;
- возвращает значение.
Если вы не указали второй параметр, он вернёт None, то есть ничего.
author.setdefault('middle_name') # None - значит ничего author # добавился ключ 'middle_name' со значением None >>> < 'first_name': 'Виктор', 'last_name': 'Пелевин', 'username': 'dao1962', 'middle_name': None, > author.setdefault('book', 'Омон Ра') >>> 'Омон Ра' author >>> < 'first_name': 'Виктор', 'last_name': 'Пелевин', 'username': 'dao1962', 'middle_name': None, 'book': 'Омон Ра', >
Обратите внимание, что этот метод не меняет значения у существующих ключей.
Dictionary (Словари)
Словарь (неупорядоченные коллекции из разных объектов с доступом по ключу) создаётся при помощи фигурных скобок, внутри которых указываются пары «ключ-значение» через запятые. Также можно создать пустой словарь и позже добавлять пары. В Python словарь определён в классе dict. Иногда используют термин ассоциативные массивы или хеш-таблицы.
catDictionary = emptyDictionary = <>
Другие варианты создания словарей.
С помощью функции dict():
dictionary = dict(short='dict', long='dictionary') print(dictionary) # numberDict = dict([(1, 3), (2, 9)]) print(numberDict) #
С помощью метода fromkeys():
noneDictionary = dict.fromkeys(['a', 'b']) print(noneDictionary) # fullDictionary = dict.fromkeys(['a', 'b'], 9) print(fullDictionary) #
И ключи и значения в одном словаре могут быть разных типов (строки, числа).
Ключи и значения могут выводиться в различном порядке, потому что словари, в отличие от списков, не упорядочены (не ранжированы). В словаре нет первого элемента, потому что нет какого-нибудь порядка расположения элементов.
Число пар в словаре можно получить через len.
print(len(catDictionary)) # 3
Доступ к значению можно получить через ключ, указанный в квадратных скобках. Если указать неправильный ключ, то вернётся ошибка.
print(catDictionary["key3"]) # Vaska
Также можно через метод get().
val = catDictionary.get("key2") print(val) # Murzik
При не существующем ключе можно вернуть собственное сообщение.
val = catDictionary.get("key5", "That key is not found") print(val)
Проверить, есть ли проверяемый ключ в словаре можно через оператор in. В успешном случае возвращается True или 1, в противном случае возвращается False или 0.
print("key4" in catDictionary) # 0 print("key1" in catDictionary) # True
Получить все ключи можно через keys(). Метод возвращает значение типа dict_keys.
keys = catDictionary.keys() print(list(keys))
Получить все значения ключей можно через values(). Метод возвращает значение типа dict_values.
values = catDictionary.values() print(list(values)) # ['Murzik', 'Vaska', 'Barsik']
Получить все ключи со значениями можно через items().
items = catDictionary.items() print(items) # dict_items([('key2', 'Murzik'), ('key3', 'Vaska'), ('key1', 'Barsik')])
Чтобы обновить значение в словаре, нужно указать ключ и новое значение.
catDictionary["key1"] = "Ryzhik"
По такому же принципу можно добавить новый ключ со значением.
catDictionary["key4"] = "Murka"
Удалить элемент (ключ-значение) можно через оператор del. Также можно удалить весь словарь.
del catDictionary["key4"] del catDictionary
Если мы не хотим удалять сам словарь, а только очистить его от элементов, то воспользуемся методом clear().
catDictionary.clear() print(catDictionary) # <>
Выражение favorites1 == favorites2 истинно потому, что словари не упорядочены и считаются эквивалентными, если состоят из одинаковых пар ключ-значение.
Списки с одинаковыми значениями элементов, но разным порядком их следования, равны не будут.
favorites1 = favorites2 = favorites1 == favorites2 # True
Получение списка ключей из словаря в Python
Часто при работе со словарями в Python возникает необходимость получить список всех ключей этого словаря. Например, есть словарь, где каждому имени студента сопоставлена его оценка:
grades =
В Python 2.7 для получения списка ключей словаря можно было использовать метод keys() . Результатом его выполнения был список всех ключей:
print(grades.keys()) # Вывод: ['Иван', 'Мария', 'Алексей']
Однако, начиная с версии Python 3.3, поведение этого метода изменилось. Теперь он возвращает не список, а специальный объект dict_keys :
print(grades.keys()) # Вывод: dict_keys(['Иван', 'Мария', 'Алексей'])
Такой объект ведет себя похоже на список: его можно перебирать в цикле, проверять на вхождение элементов и так далее. Однако он не поддерживает некоторые операции, доступные для списков, например, индексацию.
Как получить список ключей словаря в Python 3?
Для получения списка ключей словаря в Python 3 нужно явно преобразовать объект dict_keys в список. Для этого можно использовать встроенную функцию list() .
grades = keys_list = list(grades.keys()) print(keys_list) # Вывод: ['Иван', 'Мария', 'Алексей']
Такой подход позволяет получить список ключей, с которым затем можно работать как с обычным списком, используя все доступные для него операции.