# Отчет по теме 3 Коломейцев Дмитрий, А-02-23 ## Тема 3. Операции с объектами ## 1-2. Преобразование простых типов объектов ### 2.1 Преобразование в логический тип с помощью функции bool(<Объект>): ```py logiz1=bool(56) logiz1 True type(logiz1) logiz2=bool(0) logiz2 False type(logiz2) logiz3=bool("Beta") logiz3 True type(logiz3) logiz4=bool("") logiz4 False type(logiz4) logiz5=bool("Infinity") logiz5 True type(logiz5) ``` ### 2.2 Преобразование в целое десятичное число объекта с заданной системой счисления. По умолчанию система счисления принимается десятичной: ```py tt1=int(198.6) tt1 198 type(tt1) tt2=int("-76") tt2 -76 type(tt2) tt3=int("B",16) tt3 11 type(tt3) tt4=int("71",8) tt4 57 type(tt4) tt5=int("98.76") Traceback (most recent call last): File "", line 1, in tt5=int("98.76") ValueError: invalid literal for int() with base 10: '98.76' ``` _Объяснение последнего вызова: функция int() в Python принимает только строки, которые представляют целые числа без десятичной части. Когда программа пытается выполнить int("98.76"), Python обнаруживает символ точки (.) в строке и не может интерпретировать её как допустимое целое число._ Преобразование целых чисел или строк символов в вещественное число. Преобразования выполняются с помощью функции float(<Объект>). Примеры преобразований: ```py flt1=float(789) flt1 789.0 type(flt1) flt2=float(-6.78e2) flt2 -678.0 type(flt2) flt3=float("Infinity") flt3 inf type(flt3) flt4=float("-inf") flt4 -inf type(flt4) ``` ### 2.3 Преобразование десятичных чисел в другие системы счисления: ```py hh=123 dv1=bin(hh) dv1 '0b1111011' type(dv1) vos1=oct(hh) vos1 '0o173' type(vos1) shs1=hex(hh) shs1 '0x7b' type(shs1) int(dv1,2) 123 ``` ## 3. Преобразование сложных базовых типов объектов ### 3.1 Преобразование в строку символов с помощью функции str(<Объект>). Примеры: ```py strk1=str(23.6) strk1 '23.6' strk2=str(logiz3) strk2 'True' strk3=str(["A","B","C"]) strk3 "['A', 'B', 'C']" strk4=str(("A","B","C")) strk4 "('A', 'B', 'C')" strk5=str({"A":1,"B":2,"C":9}) strk5 "{'A': 1, 'B': 2, 'C': 9}" ``` Создайте строку со своей фамилией и инициалами, преобразуйте её в список, затем список – в кортеж и, наконец, кортеж – в строку. ```py fio="Kolomeytsev D.A." fio=list(fio) fio ['K', 'o', 'l', 'o', 'm', 'e', 'y', 't', 's', 'e', 'v', ' ', 'D', '.', 'A', '.'] fio=tuple(fio) fio ('K', 'o', 'l', 'o', 'm', 'e', 'y', 't', 's', 'e', 'v', ' ', 'D', '.', 'A', '.') fio=str(fio) fio "('K', 'o', 'l', 'o', 'm', 'e', 'y', 't', 's', 'e', 'v', ' ', 'D', '.', 'A', '.')" ``` ### 3.2 Преобразование элементов объекта в список с помощью функции list(<Объект>). ```py spis1=list("Строка символов") spis1 ['С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в'] spis2=list((124,236,-15,908)) spis2 [124, 236, -15, 908] spis3=list({"A":1,"B":2,"C":9}) spis3 ['A', 'B', 'C'] spis4=list({"A":1,"B":2,"C":9}.values()) spis4 [1, 2, 9] spis5=list({"A":1,"B":2,"C":9}.items()) spis5 [('A', 1), ('B', 2), ('C', 9)] ``` ### 3.3.Преобразование элементов объектов в кортеж с помощью функции tuple(<Объект>). ```py kort7=tuple('Строка символов') kort7 ('С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в') kort8=tuple(spis2) kort8 (124, 236, -15, 908) kort9=tuple({"A":1,"B":2,"C":9}) kort9 ('A', 'B', 'C') # Извлекаются только ключи tuple({"A":1,"B":2,"C":9}.values()) (1, 2, 9) tuple({"A":1,"B":2,"C":9}.items()) (('A', 1), ('B', 2), ('C', 9)) ``` ### 3.4. Удаление объектов ```py dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'hh', 'kort7', 'kort8', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'logiz5', 'shs1', 'spis1', 'spis2', 'spis3', 'strk1', 'strk2', 'strk3', 'strk4', 'strk5', 'tt1', 'tt2', 'tt3', 'tt4', 'vos1'] del strk5, kort8 dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'hh', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'logiz5', 'shs1', 'spis1', 'spis2', 'spis3', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'vos1'] ``` ## 4. Арифметические операции ```py 12+7+90 109 5.689e-1 - 0.456 0.11289999999999994 23.6+54 77.6 14-56.7+89 46.3 -6.7*12 -80.4 -234.5/6 -39.083333333333336 a=178/45 a 3.9555555555555557 b=178//45 b 3 c=-24.6//12.1 c -3.0 148%33 16 12.6%3.8 1.2000000000000002 14**3 2744 e=2.7**3.6 e 35.719843790663525 ``` Операции с комплексными числами: ```py # Операции с комплексными числами c1=3+4j c2=1+2j # Сложение - работает c1+c2 (4+6j) # Вычитание - работает c1-c2 (2+2j) # Умножение - работает c1*c2 (-5+10j) # Деление - работает c1/c2 (2.2-0.4j) # Возведение в степень - работает c1**2 (-7+24j) c2**3 (-11-2j) 2**c1 (-0.2248450953661021+0.11208386718098048j) # Смешанные операции - работают c1+5 (8+4j) 3*c2 (3+6j) c1**2.5 (-55.32248306929338+48.80907018181927j) # Операции, которые НЕ работают с комплексными числами: c1//c2 Traceback (most recent call last): File "", line 1, in c1//c2 TypeError: unsupported operand type(s) for //: 'complex' and 'complex' c1%c2 Traceback (most recent call last): File "", line 1, in c1%c2 TypeError: unsupported operand type(s) for %: 'complex' and 'complex' c1>c2 Traceback (most recent call last): File "", line 1, in c1>c2 TypeError: '>' not supported between instances of 'complex' and 'complex' c1", line 1, in c1", line 1, in 148%c TypeError: unsupported operand type(s) for %: 'int' and 'complex' 14**3 2744 14.5**3 3048.625 c**5 (-38+41j) ``` ## 5. Операции с двоичными представлениями целых чисел. ### 5.1. Двоичная инверсия (~). Значение каждого бита в представлении числа заменяется на противоположное значение (0 на 1, 1 на 0). ```py dv1=9 dv2=~dv1 dv1 9 dv2 -10 ``` ### 5.2. Двоичное «И» (&). Побитовое совпадение двоичных представлений чисел: ```py 7&9 # 111 и 1001 = 0001 1 7&8 # 111 и 1000 = 000 0 ``` ### 5.3. Двоичное «ИЛИ» (|). Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда равны 0: ```py 7|9 # 111 или 1001 = 1111 15 7|8 # 111 или 1000 = 1111 15 14|5 # 1110 или 0101 = 1111 15 ``` ### 5.4.Двоичное «исключающее ИЛИ»(^). Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда имеют одинаковые значения – оба 0 или оба 1 ```py 14^5 # 1110 исключающее или 0101 = 1011 11 ``` ### 5.5. Сдвиг двоичного представления на заданное число разрядов. Влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева. ```py h=14 #Двоичное представление = 1110 g=h<<2 # Новое двоичное представление =111000 g 56 g1=h>>1 # Новое двоичное представление= 0111 g1 7 g2=h>>2 # Новое двоичное представление= 0011 g2 3 ``` Пример работы двух двоичных чисел из 7 знаков: ```py a = 0b1010101 # 85 в десятичной системе b = 0b1100100 # 100 в десятичной системе a 85 b 100 a<<2 340 b>>2 25 b 102 ~b -101 ~a -86 (b&a) 68 ``` ## 6. Операции при работе с последовательностями (строками, списками, кортежами). ```py stroka='Stroka' dir(stroka) ['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill'] ``` ### 6.1. Объединение последовательностей (конкатенация)(+) ```py 'Система '+'регулирования' #Соединение двух строк символов 'Система регулирования' ['abc','de','fg']+['hi','jkl'] # Объединение двух списков ['abc', 'de', 'fg', 'hi', 'jkl'] ('abc','de','fg')+('hi','jkl') # Объединение двух кортежей ('abc', 'de', 'fg', 'hi', 'jkl') ``` ### 6.2. Повторение (*) ```py 'ля-'*5 #Повторение строки 5 раз 'ля-ля-ля-ля-ля-' ['ку','-']*3 #Повторение списка 3 раза ['ку', '-', 'ку', '-', 'ку', '-'] ('кис','-')*4 #Повторение кортежа 4 раза ('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-') signal1=[0]*3+[1]*99 signal1 [0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] signal2=(0,)*3+(1,)*5+(0,)*7 signal2 (0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0) ``` ### 6.3. Проверка наличия заданного элемента в последовательности (in) ```py stroka='Система автоматического управления' 'автомат' in stroka #Наличие подстроки в строке True 'ку' in ['ку','-']*3 #Наличие контекста в списке True 'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl') #Наличие контекста в кортеже False ``` ### 6.4.Подстановка значений в строку с помощью оператора «%» ```py # Пример 1. stroka='Температура = %g %s %g' stroka 'Температура = %g %s %g' stroka % (16,' меньше ',25) 'Температура = 16 меньше 25' # Пример 2. Вставка с использованием данных из словаря. stroka='Температура = %(zn1)g %(sravn)s %(zn2)g' stroka 'Температура = %(zn1)g %(sravn)s %(zn2)g' stroka % {'zn1':16,'sravn':' меньше ','zn2':25} 'Температура = 16 меньше 25' ``` ## 7. Оператор присваивания ### 7.1. Обычное присваивание значения переменной (=) ```py zz=-12 zz -12 ``` ### 7.2.Увеличение значения переменной на заданную величину (+=) или уменьшение (-=) ```py zz+=5 # Значение zz увеличивается на 5 zz -7 zz-=3 # Значение уменьшается на 3 zz -10 ``` Для последовательностей операция (+=) означает конкатенацию текущего значения объекта с заданным дополнением. ```py stroka='Система' stroka 'Система' stroka+=' регулирования' stroka 'Система регулирования' ``` ### 7.3. Умножение текущего значения переменной на заданную величину (*=) или деление (/=) ```py zz=-12 zz/=2 zz -6.0 zz*=5 zz -30.0 zz*=5.4 zz -162.0 zz//=80 zz -3.0 zz**=4 zz 81.0 ``` ### 7.4.Операции деления ```py zz//=4 zz -7.0 zz -25.0 zz//=4 zz -7.0 -25//4 -7 25//4 6 zz=-5 zz%= 2 zz 1 zz*=2 zz 2 zz**=6 zz 64 ``` ### 7.5. Множественное присваивание ```py w=v=10 # Переменным присваивается одно и то жезначение >>> w 10 >>> v 10 n1,n2,n3=(11,-3,'all') #Значения переменных берутсяиз кортежа >>> n1 11 >>> n2 -3 >>> n3 'all' ``` Можно использовать множественное присваивание с разными типами данных - Python поддерживает распаковку любых итерируемых объектов. Вот примеры для каждого типа: Использование строки: ```py a,b,c="ABC" a 'A' b 'B' c 'C' ``` Работает. Строка разбивается на отдельные символы. Использование списка: ```py x,y,z=[10,20,30] x 10 y 20 z 30 ``` Работает. Элементы списка распаковываются по порядку. Использование словаря: ```py p,q,r={'key1':1,'key2':2,'key3':3} p 'key1' q 'key2' r 'key3' ``` Работает, но распаковываются только КЛЮЧИ, не значения. Это важная особенность словарей - при итерации по умолчанию используются ключи. Для распаковки значений нужно использовать: ```py p,q,r={'key1':1,'key2':2,'key3':3}.values() p 1 q 2 r 3 ``` Использование множества: ```py m,n,o={100,200,300} m 200 # Порядок может быть другим! n 100 o 300 ``` Работает, но порядок НЕ ГАРАНТИРОВАН - множества неупорядочены, поэтому значения могут распаковаться в любой последовательности. ## 8. Логические операции Используются при создании логических выражений, дающих в результате вычисления значения True или False. ### 8.1. Операции сравнения Равенство (==), не равно (!=), меньше (<), больше (>), меньше или равно (<=), больше или равно (>=) – придумайте примеры этих операций. Сравните ранее созданные переменные w и v. ### 8.2. Проверка наличия заданного элемента в последовательности Или во множестве, а также проверка наличия ключа в словаре (in). Операции с множеством: ```py mnoz1={'pen','book','pen','iPhone','table','book'} dir(mnoz1) ['__and__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__iand__', '__init__', '__init_subclass__', '__ior__', '__isub__', '__iter__', '__ixor__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__rand__', '__reduce__', '__reduce_ex__', '__repr__', '__ror__', '__rsub__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__xor__', 'add', 'clear', 'copy', 'difference', 'difference_update', 'discard', 'intersection', 'intersection_update', 'isdisjoint', 'issubset', 'issuperset', 'pop', 'remove', 'symmetric_difference', 'symmetric_difference_update', 'union', 'update'] 'book' in mnoz1 True 'cap' in mnoz1 False ``` Операции со словарем: ```py dic1={'Saratov':145, 'Orel':56, 'Vologda':45} ['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values'] 'Vologda' in dic1 True 'Pskov' in dic1 False 56 in dic1.values() True dct1={'Institut':['AVTI','IEE','IBB'],'Depart':['UII','PM','VMSS','MM'],'gruppa': ['A-01-15','A-02-15']} 'UII' in dct1['Depart'] True dct1['Depart'][1] == 'MM' False ``` ### 8.3. Создание больших логических выражений с использованием соединительных слов Логическое «И» (and), логическое «ИЛИ» (or), логическое «НЕ» (not). ```py a=17 b=-6 (a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1) True (a=b) and (a==b) and not (a!=b) False ``` ### 8.4.Проверка ссылок переменных на один и тот же объект (is). ```py w=v=10 #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти w is v # Числа до 500 в питоне имеют одинаковый адрес/хэш в памяти True w1=['A','B'] v1=['A','B'] w1 is v1 False #Они задавались отдельно друг от друга ``` ## 9. Операции с объектами, выполняемые с помощью методов. ```py stroka='Микропроцессорная система управления' #получение полного списка атрибутов dir(stroka) ['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill'] ``` ### 9.1. Методы для работы со строками. ```py stroka.find('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1 5 stroka.count("с") #Подсчет числа вхождений строки “с” в stroka 4 stroka.replace(' у',' автоматического у') 'Микропроцессорная система автоматического управления' spis22=stroka.split(' ') #Возвращает список подстрок, между которыми в строке стоит заданный разделитель spis22 ['Микропроцессорная', 'система', 'управления'] stroka.upper() #Возвращает строку со всеми заглавными буквами 'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ' stroka3=" ".join(spis22) #Возвращает строку, собранную из элементов списка stroka3 'Микропроцессорная система управления' stroka3.partition("с") #Возвращает кортеж с результатами поиска «с» слева ('Микропроце', 'с', 'сорная система управления') stroka3.rpartition("с") #Возвращает кортеж с результатами поиска «с» справа ('Микропроцессорная си', 'с', 'тема управления') strk1='Момент времени {}, значение = {}' strk1.format(1,89.7) 'Момент времени 1, значение = 89.7' strk2='Момент времени {1}, значение = {0}:{2}' strk2.format(36.7,2,'норма!') 'Момент времени 2, значение = 36.7:норма!' strk3='Момент времени {num}, значение = {znch}' strk3.format(znch=89.7,num=2) 'Момент времени 2, значение = 89.7' ``` ### 9.2. Методы для работы со списками. ```py spsk=[1,'a',2,'b',3,'c',4] dir(spsk) #отображение атрибутов ['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort'] spsk.pop(2) #удаляет из списка элемент с индексом 2 и выводит его 2 spsk [1, 'a', 'b', 3, 'c', 4] spsk.append('c') #добавление в конец списка 'c' spsk [1, 'a', 'b', 3, 'c', 4, 'c'] spsk.insert(2,'a') #вставляет 'a' на позицию с индексом 2 spsk [1, 'a', 'a', 'b', 3, 'c', 4, 'c'] spsk.count('a') #считает количество 'a' в списке 2 ``` ### 9.3. Методы для работы с кортежами. ```py kortezh = (1, 'a', 'b', 3, 'c', 4) dir(kortezh) ['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'count', 'index'] kortezh.count(3) #считает количество 3 в списке 1 kortezh.index('b') #выводит с каким индексом в кортеже 'b' 2 kortezh + (5, 6) #добавляет 5, 6 в кортеж (1, 'a', 'b', 3, 'c', 4, 5, 6) ``` ### 9.4. Методы для работы со словарями. ```py slvr = {'a': 1, 'b': 2, 'c': 3, 'd': 4} dir(slvr) ['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values'] slvr.keys() #получение ключей словаря dict_keys(['a', 'b', 'c', 'd']) slvr.values() #получение значений словаря dict_values([1, 2, 3, 4]) slvr.items() #получение пар ключ-значение из словаря dict_items([('a', 1), ('b', 2), ('c', 3), ('d', 4)]) slvr.get('b') #получение значений по ключу 2 slvr.update({'e': 5, 'f': 6}) #добавление двух пар в словарь slvr {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6} slvr.pop('c') #удаление по ключу 3 slvr {'a': 1, 'b': 2, 'd': 4, 'e': 5, 'f': 6} ``` ### 9.5. Методы для работы с множествами. ```py mng={1,'a',2,'b',3,'c',4} dir(mng) ['__and__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__iand__', '__init__', '__init_subclass__', '__ior__', '__isub__', '__iter__', '__ixor__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__rand__', '__reduce__', '__reduce_ex__', '__repr__', '__ror__', '__rsub__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__xor__', 'add', 'clear', 'copy', 'difference', 'difference_update', 'discard', 'intersection', 'intersection_update', 'isdisjoint', 'issubset', 'issuperset', 'pop', 'remove', 'symmetric_difference', 'symmetric_difference_update', 'union', 'update'] mng.add('d') #добавление в множество mng элемента 'd' mng {1, 2, 3, 'c', 4, 'a', 'b', 'd'} mng.remove(3) #удаление из множества mng элемента 3 mng {1, 2, 'c', 4, 'a', 'b', 'd'} mng1={5,'e',6} mng2=mng.union(mng1) #объединение множеств mng и mng1 mng2 {1, 2, 'c', 4, 5, 6, 'a', 'b', 'e', 'd'} mng3=mng2.intersection(mng) #пересечение множеств mng и mng2, получили mng так как mng входит в mng2 mng3 {1, 2, 4, 'a', 'b', 'd', 'c'} mng4=mng2.difference(mng) #разность множеств mng и mng2, получили mng1, так как mng+mng1=mng2 mng4 {'e', 5, 6} ``` ## 10. Сохранил файл и закончил сеанс работы с IDLE.