27 KiB
Отчет по теме 3
Коломейцев Дмитрий, А-02-23
Тема 3. Операции с объектами
1-2. Преобразование простых типов объектов
2.1 Преобразование в логический тип с помощью функции bool(<Объект>):
logiz1=bool(56)
logiz1
True
type(logiz1)
<class 'bool'>
logiz2=bool(0)
logiz2
False
type(logiz2)
<class 'bool'>
logiz3=bool("Beta")
logiz3
True
type(logiz3)
<class 'bool'>
logiz4=bool("")
logiz4
False
type(logiz4)
<class 'bool'>
logiz5=bool("Infinity")
logiz5
True
type(logiz5)
<class 'bool'>
2.2 Преобразование в целое десятичное число объекта с заданной системой счисления.
По умолчанию система счисления принимается десятичной:
tt1=int(198.6)
tt1
198
type(tt1)
<class 'int'>
tt2=int("-76")
tt2
-76
type(tt2)
<class 'int'>
tt3=int("B",16)
tt3
11
type(tt3)
<class 'int'>
tt4=int("71",8)
tt4
57
type(tt4)
<class 'int'>
tt5=int("98.76")
Traceback (most recent call last):
File "<pyshell#20>", line 1, in <module>
tt5=int("98.76")
ValueError: invalid literal for int() with base 10: '98.76'
Объяснение последнего вызова: функция int() в Python принимает только строки, которые представляют целые числа без десятичной части. Когда программа пытается выполнить int("98.76"), Python обнаруживает символ точки (.) в строке и не может интерпретировать её как допустимое целое число.
Преобразование целых чисел или строк символов в вещественное число. Преобразования выполняются с помощью функции float(<Объект>). Примеры преобразований:
flt1=float(789)
flt1
789.0
type(flt1)
<class 'float'>
flt2=float(-6.78e2)
flt2
-678.0
type(flt2)
<class 'float'>
flt3=float("Infinity")
flt3
inf
type(flt3)
<class 'float'>
flt4=float("-inf")
flt4
-inf
type(flt4)
<class 'float'>
2.3 Преобразование десятичных чисел в другие системы счисления:
hh=123
dv1=bin(hh)
dv1
'0b1111011'
type(dv1)
<class 'str'>
vos1=oct(hh)
vos1
'0o173'
type(vos1)
<class 'str'>
shs1=hex(hh)
shs1
'0x7b'
type(shs1)
<class 'str'>
int(dv1,2)
123
3. Преобразование сложных базовых типов объектов
3.1 Преобразование в строку символов с помощью функции str(<Объект>).
Примеры:
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}"
Создайте строку со своей фамилией и инициалами, преобразуйте её в список, затем список – в кортеж и, наконец, кортеж – в строку.
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(<Объект>).
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']
3.3.Преобразование элементов объектов в кортеж с помощью функции tuple(<Объект>).
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. Удаление объектов
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. Арифметические операции
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
Операции с комплексными числами:
# Операции с комплексными числами
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 "<pyshell#95>", line 1, in <module>
c1//c2
TypeError: unsupported operand type(s) for //: 'complex' and 'complex'
c1%c2
Traceback (most recent call last):
File "<pyshell#96>", line 1, in <module>
c1%c2
TypeError: unsupported operand type(s) for %: 'complex' and 'complex'
c1>c2
Traceback (most recent call last):
File "<pyshell#97>", line 1, in <module>
c1>c2
TypeError: '>' not supported between instances of 'complex' and 'complex'
c1<c2
Traceback (most recent call last):
File "<pyshell#98>", line 1, in <module>
c1<c2
TypeError: '<' not supported between instances of 'complex' and 'complex'
Операции со смешанными типами:
178//45.0
3.0
(2+1j)
178/c
(71.2-35.6j)
148%33
16
148.0%33
16.0
148%c
Traceback (most recent call last):
File "<pyshell#99>", line 1, in <module>
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).
dv1=9
dv2=~dv1
dv1
9
dv2
-10
5.2. Двоичное «И» (&).
Побитовое совпадение двоичных представлений чисел:
7&9 # 111 и 1001 = 0001
1
7&8 # 111 и 1000 = 000
0
5.3. Двоичное «ИЛИ» (|).
Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда равны 0:
7|9 # 111 или 1001 = 1111
15
7|8 # 111 или 1000 = 1111
15
14|5 # 1110 или 0101 = 1111
15
5.4.Двоичное «исключающее ИЛИ»(^).
Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда имеют одинаковые значения – оба 0 или оба 1
14^5 # 1110 исключающее или 0101 = 1011
11
5.5. Сдвиг двоичного представления на заданное число разрядов.
Влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева.
h=14 #Двоичное представление = 1110
g=h<<2 # Новое двоичное представление =111000
g
56
g1=h>>1 # Новое двоичное представление= 0111
g1
7
g2=h>>2 # Новое двоичное представление= 0011
g2
3
Пример работы двух двоичных чисел из 7 знаков:
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. Операции при работе с последовательностями (строками, списками, кортежами).
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. Объединение последовательностей (конкатенация)(+)
'Система '+'регулирования' #Соединение двух строк символов
'Система регулирования'
['abc','de','fg']+['hi','jkl'] # Объединение двух списков
['abc', 'de', 'fg', 'hi', 'jkl']
('abc','de','fg')+('hi','jkl') # Объединение двух кортежей
('abc', 'de', 'fg', 'hi', 'jkl')
6.2. Повторение (*)
'ля-'*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)
stroka='Система автоматического управления'
'автомат' in stroka #Наличие подстроки в строке
True
'ку' in ['ку','-']*3 #Наличие контекста в списке
True
'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl') #Наличие контекста в кортеже
False
6.4.Подстановка значений в строку с помощью оператора «%»
# Пример 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. Обычное присваивание значения переменной (=)
zz=-12
zz
-12
7.2.Увеличение значения переменной на заданную величину (+=) или уменьшение (-=)
zz+=5 # Значение zz увеличивается на 5
zz
-7
zz-=3 # Значение уменьшается на 3
zz
-10
Для последовательностей операция (+=) означает конкатенацию текущего значения объекта с заданным дополнением.
stroka='Система'
stroka
'Система'
stroka+=' регулирования'
stroka
'Система регулирования'
7.3. Умножение текущего значения переменной на заданную величину (*=) или деление (/=)
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.Операции деления
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. Множественное присваивание
w=v=10 # Переменным присваивается одно и то жезначение
>>> w
10
>>> v
10
n1,n2,n3=(11,-3,'all') #Значения переменных берутсяиз кортежа
>>> n1
11
>>> n2
-3
>>> n3
'all'
Можно использовать множественное присваивание с разными типами данных - Python поддерживает распаковку любых итерируемых объектов. Вот примеры для каждого типа:
Использование строки:
a,b,c="ABC"
a
'A'
b
'B'
c
'C'
Работает. Строка разбивается на отдельные символы.
Использование списка:
x,y,z=[10,20,30]
x
10
y
20
z
30
Работает. Элементы списка распаковываются по порядку.
Использование словаря:
p,q,r={'key1':1,'key2':2,'key3':3}
p
'key1'
q
'key2'
r
'key3'
Работает, но распаковываются только КЛЮЧИ, не значения. Это важная особенность словарей - при итерации по умолчанию используются ключи.
Для распаковки значений нужно использовать:
p,q,r={'key1':1,'key2':2,'key3':3}.values()
p
1
q
2
r
3
Использование множества:
m,n,o={100,200,300}
m
200 # Порядок может быть другим!
n
100
o
300
Работает, но порядок НЕ ГАРАНТИРОВАН - множества неупорядочены, поэтому значения могут распаковаться в любой последовательности.
8. Логические операции
Используются при создании логических выражений, дающих в результате вычисления значения True или False.
8.1. Операции сравнения
Равенство (==), не равно (!=), меньше (<), больше (>), меньше или равно (<=), больше или равно (>=) – придумайте примеры этих операций. Сравните ранее созданные переменные w и v.
8.2. Проверка наличия заданного элемента в последовательности
Или во множестве, а также проверка наличия ключа в словаре (in). Операции с множеством:
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
Операции со словарем:
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).
a=17
b=-6
(a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1)
True
(a<b) and ('Vologda' in dic1) and ('cap' in mnoz1)
False
(a>=b) and (a==b) and not (a!=b)
False
8.4.Проверка ссылок переменных на один и тот же объект (is).
w=v=10 #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти
w is v
# Числа до 500 в питоне имеют одинаковый адрес/хэш в памяти
True
w1=['A','B']
v1=['A','B']
w1 is v1
False #Они задавались отдельно друг от друга
9. Операции с объектами, выполняемые с помощью методов.
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. Методы для работы со строками.
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. Методы для работы со списками.
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. Методы для работы с кортежами.
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. Методы для работы со словарями.
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. Методы для работы с множествами.
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}