Академия Eduson

Словари. Вложенные словари, генераторы

Вложенные словари и генераторы словарей

 Как записывается генератор словаря?

 Ответ: {ключ: значение for переменная in последовательность}

 Как извлечь из словаря students возраст Тимура?:

students = {1: {'name': 'Тимур', 'age': '28', 'sex': 'Male'},
            2: {'name': 'Руслан', 'age': '22', 'sex': 'Male'},
            3: {'name': 'Соня', 'age': '25', 'sex': 'Female'}}

 Ответ:  students[1]['age']

 Сопоставьте код (в левом столбце) с выводом (в правом столбце), если словарь states имеет вид:

states = {'California': {'population': 39512223, 'capital': 'Sacramento', 'landlocked': False}, 
          'Oregon': {'population': 4217737, 'capital': 'Salem', 'landlocked': False}, 
          'Nevada': {'population': 3080156, 'capital': 'Carson City', 'landlocked': True}}

 Ответ:

  • states['California']['population'] 39512223;
  • states['Nevada']['landlocked'] True;
  • states['capital']['California'] произойдет ошибка: KeyError: 'capital';
  • states['California']['landlocked'] False;
  • states['Oregon']['capital'] 'Salem';
  • states['Oregon']['area'] произойдет ошибка: KeyError: 'area';
  • states['Nevada']['population'] 3080156;
  • states['Nevada']['capital'] 'Carson City';
  • states['Connecticut']['population'] произойдет ошибка: KeyError: 'Connecticut'

 Как извлечь из словаря marks оценку по истории?:

marks = { 
   'class':{ 
      'student':{ 
         'name':'Rosaly',
         'marks':{ 
            'physics':70,
            'history':80
         }
      }
   }
}

 Ответ:  marks['class']['student']['marks']['history']

 Дополните приведенный код, используя генератор, так, чтобы получить словарь result, в котором ключом будет позиция числа в списке numbers (начиная с 0), а значением – его квадрат.

numbers = [34, 10, -4, 6, 10, 23, -90, 100, 21, -35, -95, 1, 36, -38, -19, 1, 6, 87]

result = {i: numbers[i]**2 for i in range(len(numbers))}

 Дополните приведенный код, используя генератор, чтобы получить словарь result, состоящий из всех элементов словаря colors, кроме тех, у которых значением является None.

colors = {'c1': 'Red', 'c2': 'Grey', 'c3': None, 'c4': 'Green', 'c5': 'Yellow', 'c6': 'Pink', 'c7': 'Orange', 'c8': None, 'c9': 'White', 'c10': 'Black', 'c11': 'Violet', 'c12': 'Gold', 'c13': None, 'c14': 'Amber', 'c15': 'Azure', 'c16': 'Beige', 'c17': 'Bronze', 'c18': None, 'c19': 'Lilac', 'c20': 'Pearl', 'c21': None, 'c22': 'Sand', 'c23': None}

result = {c: colors[c] for c in colors if colors[c] != None}

 Дополните приведенный код, используя генератор, чтобы получить словарь result, состоящий из всех элементов словаря favorite_numbers , значения которых являются двузначными числами.

fav_n = {'timur': 17, 'ruslan': 7, 'larisa': 19, 'roman': 123, 'rebecca': 293, 'ronald': 76, 'dorothy': 62, 'harold': 36, 'matt': 314, 'kim': 451, 'rosaly': 18, 'rustam': 89, 'soltan': 111, 'amir': 654, 'dima': 390, 'amiran': 777, 'geor': 999, 'sveta': 75, 'rita': 909, 'kirill': 404, 'olga': 271, 'anna': 55, 'madlen': 876}

result = {i: fav_n[i] for i in fav_n if 9 < fav_n[i] < 100}

 Дополните приведенный код, используя генератор, так, чтобы получить словарь result, состоящий из всех элементов словаря months , в которых ключ и значение поменялись местами.

months = {1: 'January', 2: 'February', 3: 'March', 4: 'April', 5: 'May', 6: 'June', 7: 'July', 8: 'August', 9: 'September', 10: 'October', 11: 'November', 12: 'December'}

result = {months[m]: m for m in months}

 В переменной s хранится строка пар число:слово. Дополните приведенный код, используя генератор, чтобы получить словарь result , в котором числа будут ключами, а слова – значениями.

s = '1:men 2:kind 90:number 0:sun 34:book 56:mountain 87:wood 54:car 3:island 88:power 7:box 17:star 101:ice'

result = {int(x.split(':')[0]): x.split(':')[1] for x in s.split()}

 Используя генератор, дополните приведенный код, чтобы получить словарь result , где ключом будет элемент списка numbers, а значением – отсортированный по возрастанию список всех его делителей начиная с 1.

numbers = [34, 10, 4, 6, 10, 23, 90, 100, 21, 35, 95, 1, 36, 38, 19, 1, 6, 87, 1000, 13456, 360]

result = {x: [i for i in range(1, x + 1) if x % i == 0] for x in numbers}

 Дополните приведенный код, используя генератор, так, чтобы получить словарь result , в котором ключом будет строка – элемент списка words, а значением – список соответствующих кодов ASCII символов данной строки.

words = ['hello', 'bye', 'yes', 'no', 'python', 'apple', 'maybe', 'stepik', 'beegeek']

result = {x: [ord(i) for i in x] for x in words}

 Дополните приведенный код, используя генератор, чтобы получить словарь result, состоящий из всех элементов словаря letters , за исключением тех, ключи которых есть в списке remove_keys.

letters = {0: 'A', 1: 'B', 2: 'C', 3: 'D', 4: 'E', 5: 'F', 6: 'G', 7: 'H', 8: 'I', 9: 'J', 10: 'K', 11: 'L', 12: 'M', 13: 'N', 14: 'O', 15: 'P', 16: 'Q', 17: 'R', 18: 'S', 19: 'T', 20: 'U', 21: 'V', 22: 'W', 23: 'X', 24: 'Y', 26: 'Z'}

remove_keys = [1, 5, 7, 12, 17, 19, 21, 24]

result = {x: letters[x] for x in letters if x not in [i for i in remove_keys]}

 В переменной students хранится словарь, содержащий информацию о росте (в см) и массе (в кг) студентов. Дополните приведенный код, используя генератор, чтобы получить словарь result, состоящий из всех элементов словаря students , где указан рост больше 167 см, а масса меньше 75 кг.

students = {'Timur': (170, 75), 'Ruslan': (180, 105), 'Soltan': (192, 68), 'Roman': (175, 70), 'Madlen': (160, 50), 'Stefani': (165, 70), 'Tom': (190, 90), 'Jerry': (180, 87), 'Anna': (172, 67), 'Scott': (168, 78), 'John': (186, 79), 'Alex': (195, 120), 'Max': (200, 110), 'Barak': (180, 89), 'Donald': (170, 80), 'Rustam': (186, 100), 'Alice': (159, 59), 'Rita': (170, 80), 'Mary': (175, 69), 'Jane': (190, 80)}

result = {x: students[x] for x in students if students[x][0] > 167 and students[x][1] < 75}

 Список tuples содержит кортежи, состоящие из трех чисел. Дополните приведенный код, используя генератор, чтобы получить словарь result, в котором ключом является первый элемент каждого кортежа, а значением – кортеж из оставшихся двух элементов.

tuples = [(1, 2, 3), (4, 5, 6), (7, 8, 9), (10, 11, 12), (13, 14, 15), (16, 17, 18), (19, 20, 21), (22, 23, 24), (25, 26, 27), (28, 29, 30), (31, 32, 33), (34, 35, 36)]

result = {x[0]: x[1:] for x in tuples}

 Даны три списка student_ids, student_names, student_grades, содержащие информацию о студентах. Дополните приведенный код, используя генератор, так чтобы получить список result, содержащий вложенные словари в соответствии с образцом: [{'S001': {'Camila Rodriguez': 86}}, {'S002': {'Juan Cruz': 98}},...].

student_ids = ['S001', 'S002', 'S003', 'S004', 'S005', 'S006', 'S007', 'S008', 'S009', 'S010', 'S011', 'S012', 'S013'] 
student_names = ['Camila Rodriguez', 'Juan Cruz', 'Dan Richards', 'Sam Boyle', 'Batista Cesare', 'Francesco Totti', 'Khalid Hussain', 'Ethan Hawke', 'David Bowman', 'James Milner', 'Michael Owen', 'Gary Oldman', 'Tom Hardy'] 
student_grades = [86, 98, 89, 92, 45, 67, 89, 90, 100, 98, 10, 96, 93]

result = [{i:{n: g}} for i, n, g in zip(student_ids, student_names, student_grades)]