форкнуто от main/python-labs
				
			
			Вы не можете выбрать более 25 тем
			Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
		
		
		
		
		
			
		
			
				
	
	
		
			1202 строки
		
	
	
		
			31 KiB
		
	
	
	
		
			Markdown
		
	
			
		
		
	
	
			1202 строки
		
	
	
		
			31 KiB
		
	
	
	
		
			Markdown
		
	
# Тема 3. Операции с объектами
 | 
						|
Выполнил : Тимошенко А.А.
 | 
						|
Проверил : Козлюк Д.А.
 | 
						|
 | 
						|
## Пункт 1.
 | 
						|
```
 | 
						|
>>> import os
 | 
						|
>>> os.chdir('C:\\Users\\mapon\\OneDrive\\Рабочий стол\\ПО АС\\ТЕМА3')
 | 
						|
```
 | 
						|
## Пункт 2.
 | 
						|
 | 
						|
### Пункт 2.1
 | 
						|
 | 
						|
Преобразование в логический тип (bool())
 | 
						|
 | 
						|
Различные варианты:
 | 
						|
```
 | 
						|
>>> logiz1=bool(56)
 | 
						|
>>> logiz1
 | 
						|
True
 | 
						|
>>> logiz2=bool(0)
 | 
						|
>>> logiz2
 | 
						|
False
 | 
						|
>>> logiz3=bool("Beta")
 | 
						|
>>> logiz3
 | 
						|
True
 | 
						|
>>> logiz4=bool("")
 | 
						|
>>> logiz4
 | 
						|
False
 | 
						|
```
 | 
						|
### Пункт 2.2
 | 
						|
Преобразование в целое с заданной системой счисления (по умолчанию десятичная)
 | 
						|
```
 | 
						|
>>> tt1=int(198.6)
 | 
						|
>>> tt1
 | 
						|
198
 | 
						|
>>> tt2=int("-76")
 | 
						|
>>> tt2
 | 
						|
-76
 | 
						|
>>> tt3=int("B",16)
 | 
						|
>>> tt3
 | 
						|
11
 | 
						|
>>> tt4=int("71", 8)
 | 
						|
>>> tt4
 | 
						|
57
 | 
						|
>>> tt5=int("98.76")
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#34>", line 1, in <module>
 | 
						|
    tt5=int("98.76")
 | 
						|
ValueError: invalid literal for int() with base 10: '98.76'
 | 
						|
```
 | 
						|
В последней иструкции видим ошибку. Это происходит из-за того, что int() не может перевести строку в целочисленный тип, если указана дробная часть.
 | 
						|
 | 
						|
Преобразование в вещественное число:
 | 
						|
```
 | 
						|
>>> flt1 = float(789)
 | 
						|
>>> flt1
 | 
						|
789.0
 | 
						|
>>> flt2=float(-6.78e2)
 | 
						|
>>> flt2
 | 
						|
-678.0
 | 
						|
>>> flt3=float("Infinity")
 | 
						|
>>> flt3
 | 
						|
inf
 | 
						|
>>> flt4=float("-inf")
 | 
						|
>>> flt4
 | 
						|
-inf
 | 
						|
>>> flt5=float(False)
 | 
						|
>>> flt5
 | 
						|
0.0
 | 
						|
>>> flt6=float(True)
 | 
						|
>>> flt6
 | 
						|
1.0
 | 
						|
```
 | 
						|
### Пункт 2.3
 | 
						|
 | 
						|
Преобразование в другие системы счисления.
 | 
						|
```
 | 
						|
>>> hh=123
 | 
						|
>>> dv1 = bin(hh)
 | 
						|
>>> dv1
 | 
						|
'0b1111011'
 | 
						|
>>> vos1 = oct(hh)
 | 
						|
>>> vos1
 | 
						|
'0o173'
 | 
						|
>>> shs1 = hex(hh)
 | 
						|
>>> shs1
 | 
						|
'0x7b'
 | 
						|
```
 | 
						|
Обратный перевод с целью проверки:
 | 
						|
```
 | 
						|
>>> int(dv1, 2)
 | 
						|
123
 | 
						|
>>> int(vos1, 8)
 | 
						|
123
 | 
						|
>>> int(shs1, 16)
 | 
						|
123
 | 
						|
>>> hh == int(shs1, 16)
 | 
						|
True
 | 
						|
```
 | 
						|
 | 
						|
##  Пункт 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}"
 | 
						|
```
 | 
						|
### Пункт 3.2
 | 
						|
 | 
						|
Преобразование в список
 | 
						|
```
 | 
						|
>>> 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]
 | 
						|
```
 | 
						|
 | 
						|
### Пункт 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')
 | 
						|
```
 | 
						|
Аналогично предыдущему пункту, в кортеж попали только ключи. Значения можно записать в
 | 
						|
кортеж так:
 | 
						|
```
 | 
						|
>>> kort9 = tuple(({"A":1,"B":2,"C":9}.values()))
 | 
						|
>>> kort9
 | 
						|
(1, 2, 9)
 | 
						|
```
 | 
						|
### Пункт 3.4
 | 
						|
```
 | 
						|
>>> del strk5, kort8
 | 
						|
```
 | 
						|
Проверим:
 | 
						|
```
 | 
						|
>>> dir()
 | 
						|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__',
 | 
						|
 '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'flt5', 'flt6', 'hh', 'kort7',
 | 
						|
 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'logiz5', 'logiz6', 'logiz7', 'logiz8',
 | 
						|
 'os', 'shs1', 'spis1', 'spis2', 'spis3', 'spis4', 'spis5', 'strk1', 'strk2', 'strk3',
 | 
						|
 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'tt6', 'vos1']
 | 
						|
```
 | 
						|
 | 
						|
## Пункт 4.
 | 
						|
 | 
						|
Арифметические операции
 | 
						|
 | 
						|
### Пункт 4.1
 | 
						|
 | 
						|
Сложение и вычитание
 | 
						|
```
 | 
						|
>>> 12 + 7 + 90
 | 
						|
109
 | 
						|
>>> 5.689e-1 - 0.456
 | 
						|
0.11289999999999994 
 | 
						|
 | 
						|
>>> 23.6+54
 | 
						|
77.6
 | 
						|
>>> 14-56.7+89
 | 
						|
46.3
 | 
						|
```
 | 
						|
### Пункт 4.2
 | 
						|
 | 
						|
Умножение
 | 
						|
```
 | 
						|
>>> -6.7*12
 | 
						|
-80.4
 | 
						|
```
 | 
						|
### Пункт 4.3
 | 
						|
 | 
						|
Деление
 | 
						|
```
 | 
						|
>>> -234.5/6
 | 
						|
-39.083333333333336
 | 
						|
>>> a=178/45
 | 
						|
>>> a
 | 
						|
3.9555555555555557
 | 
						|
>>> type(a)
 | 
						|
<class 'float'>
 | 
						|
```
 | 
						|
### Пункт 4.4
 | 
						|
 | 
						|
Деление с округлением вниз (целая часть) (//)
 | 
						|
```
 | 
						|
>>> b=178//45
 | 
						|
>>> b
 | 
						|
3
 | 
						|
```
 | 
						|
Посмотрим результат обычного деления:
 | 
						|
```
 | 
						|
>>> 178/45
 | 
						|
3.9555555555555557
 | 
						|
 | 
						|
>>> c=-24.6//12.1
 | 
						|
>>> c
 | 
						|
-3.0
 | 
						|
>>> -24.6/12.1
 | 
						|
-2.0330578512396698
 | 
						|
 | 
						|
>>> d = 65.45//13
 | 
						|
>>> d
 | 
						|
5.0
 | 
						|
>>> 65.45/13
 | 
						|
5.0346153846153845
 | 
						|
 | 
						|
>>> e = 75//3.78
 | 
						|
>>> e
 | 
						|
19.0
 | 
						|
>>> 75/3.78
 | 
						|
>>> 19.841269841269842
 | 
						|
```
 | 
						|
### Пункт 4.5
 | 
						|
 | 
						|
Получение остатка от деления (%)
 | 
						|
```
 | 
						|
>>> 148%33
 | 
						|
16
 | 
						|
>>> 12.6%3.8
 | 
						|
1.2000000000000002
 | 
						|
>>> 34%2.3
 | 
						|
1.8000000000000025
 | 
						|
>>> 56.97%6
 | 
						|
2.969999999999999
 | 
						|
```
 | 
						|
### Пункт 4.6
 | 
						|
 | 
						|
Возведение в степень (**)
 | 
						|
```
 | 
						|
>>> 14**3
 | 
						|
2744
 | 
						|
>>> 2.7**3.6
 | 
						|
35.719843790663525
 | 
						|
```
 | 
						|
Попробуем проделать арифметические операции над комплексными числами. Создадим два
 | 
						|
комплексных числа
 | 
						|
```
 | 
						|
>>> comp1 = (3 + 2j)
 | 
						|
>>> type(comp1)
 | 
						|
<class 'complex'>
 | 
						|
>>> comp2 = (6 - 4j)
 | 
						|
>>> type(comp2)
 | 
						|
<class 'complex'>
 | 
						|
```
 | 
						|
Сложение
 | 
						|
```
 | 
						|
>>> comp1 + comp2
 | 
						|
(9-2j)
 | 
						|
```
 | 
						|
Вычитание
 | 
						|
```
 | 
						|
>>> comp1 - comp2
 | 
						|
(-3+6j)
 | 
						|
```
 | 
						|
Умножение
 | 
						|
```
 | 
						|
>>> comp1 * comp2
 | 
						|
(26+0j)
 | 
						|
>>> type(comp1 * comp2)
 | 
						|
<class 'complex'>
 | 
						|
```
 | 
						|
Деление
 | 
						|
```
 | 
						|
>>> comp1 / comp2
 | 
						|
(0.19230769230769232+0.46153846153846156j)
 | 
						|
```
 | 
						|
Целочисленное деление
 | 
						|
```
 | 
						|
>>> comp1 // comp2
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#30>", line 1, in <module>
 | 
						|
    comp1 // comp2
 | 
						|
TypeError: can't take floor of complex number.
 | 
						|
 | 
						|
>>> comp1 // 6
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#33>", line 1, in <module>
 | 
						|
    comp1 // 6
 | 
						|
TypeError: can't take floor of complex number.
 | 
						|
```
 | 
						|
Взятие остатка от деления
 | 
						|
```
 | 
						|
>>> comp1 % comp2
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#31>", line 1, in <module>
 | 
						|
    comp1 % comp2
 | 
						|
TypeError: can't mod complex numbers.
 | 
						|
 | 
						|
>>> comp1 % 6
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#34>", line 1, in <module>
 | 
						|
    comp1 % 6
 | 
						|
TypeError: can't mod complex numbers.
 | 
						|
```
 | 
						|
Возведение в степень
 | 
						|
```
 | 
						|
>>> comp1 ** comp2
 | 
						|
(-717.4651414273118-23072.00404010235j)
 | 
						|
```
 | 
						|
## Пункт 5
 | 
						|
 | 
						|
Операции с двоичными представлениями чисел
 | 
						|
 | 
						|
### Пункт 5.1
 | 
						|
 | 
						|
Двоичная инверсия (в двоичном виде 0 меняется на 1 и наоборот)
 | 
						|
```
 | 
						|
>>> dv1 = 9
 | 
						|
>>> dv2 = ~dv1
 | 
						|
>>> dv2
 | 
						|
-10
 | 
						|
>>> bin(dv1)
 | 
						|
'0b1001'
 | 
						|
>>> bin(dv2)
 | 
						|
'-0b1010'
 | 
						|
```
 | 
						|
Видно, что результат не совсем совпадает с ожидаемым видом "0110". Вот почему эту происходит: 
 | 
						|
в python под инверсией подразумевается смена всех 0 на 1, 1 на 0, а еще смена знака. Знак
 | 
						|
в двоичных числах записывается с помощью дополнительного кода. Получается, происходит
 | 
						|
следующее:
 | 
						|
    1. Было число 9 (1001)
 | 
						|
    2. Меняем все значения на противоположные, станет 0110
 | 
						|
    3. Теперь надо поменять знак. Чтобы поменять знак, надо, во-первых, инвертировать все
 | 
						|
    значения разрядов - будет опять 1001
 | 
						|
    4. Во-вторых, надо прибавить к полученному числу еще единицу, которая как раз и отвечает
 | 
						|
    за минус. Будет 1001 + 1 = 1010.
 | 
						|
 | 
						|
 | 
						|
### Пункт 5.2
 | 
						|
 | 
						|
Двоичное "И" (&)
 | 
						|
```
 | 
						|
>>> bin(7&9)
 | 
						|
'0b1'
 | 
						|
```
 | 
						|
Пояснение: 7 в двоичной системе счисления: 0111
 | 
						|
           9 в двоичной системе счисления: 1001
 | 
						|
           Совпадение единиц только в первом разряде, поэтому итог - 0001 или просто 1
 | 
						|
```
 | 
						|
>>> bin(7&8)
 | 
						|
'0b0'
 | 
						|
```
 | 
						|
Пояснение: 7 в двоичной системе счисления: 0111
 | 
						|
           8 в двоичной системе счисления: 1000
 | 
						|
           Совпадений единиц нет, итог - 0000 или просто 0
 | 
						|
 | 
						|
### Пункт 5.3
 | 
						|
 | 
						|
Двоичное "ИЛИ" (|)
 | 
						|
```
 | 
						|
>>> bin(7|9)
 | 
						|
'0b1111'
 | 
						|
```
 | 
						|
Пояснение: 7 в двоичной системе счисления: 0111
 | 
						|
           9 в двоичной системе счисления: 1001
 | 
						|
           Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов
 | 
						|
           есть единица, поэтому итог - 1111
 | 
						|
```           
 | 
						|
>>> bin(7|8)
 | 
						|
'0b1111'
 | 
						|
```
 | 
						|
Пояснение: 7 в двоичной системе счисления: 0111
 | 
						|
           8 в двоичной системе счисления: 1000
 | 
						|
           Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов
 | 
						|
           есть единица, поэтому итог - 1111
 | 
						|
```           
 | 
						|
>>> bin (14|5)
 | 
						|
'0b1111'
 | 
						|
```
 | 
						|
Пояснение: 14 в двоичной системе счисления: 1110
 | 
						|
           5 в двоичной системе счисления: 0101
 | 
						|
           Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов
 | 
						|
           есть единица, поэтому итог - 1111
 | 
						|
 | 
						|
### Пункт 5.4
 | 
						|
 | 
						|
(возвращается единица, если оба разряда разные)
 | 
						|
```
 | 
						|
>>> bin(14^5)
 | 
						|
'0b1011'
 | 
						|
```
 | 
						|
Пояснение: 14 в двоичной системе счисления: 1110
 | 
						|
           5 в двоичной системе счисления: 0101
 | 
						|
           Возвращается 1, если оба разряда разные, поэтому итог - 1011
 | 
						|
           
 | 
						|
В десятичном представлении:
 | 
						|
```
 | 
						|
>>> 14^5
 | 
						|
11
 | 
						|
```
 | 
						|
### Пункт 5.5
 | 
						|
 | 
						|
Побитовый сдвиг (<< влево) и (>> вправо).
 | 
						|
Биты, которые "выпадают" за пределы числа, отбрасываются.
 | 
						|
Освободившиеся позиции заполняются нулями.
 | 
						|
```
 | 
						|
>>> h = 14
 | 
						|
>>> bin(h)
 | 
						|
'0b1110'
 | 
						|
```
 | 
						|
Сдвиг на два разряда влево:
 | 
						|
```
 | 
						|
>>> g = h << 2
 | 
						|
>>> g
 | 
						|
56
 | 
						|
```
 | 
						|
Пояснение:
 | 
						|
```
 | 
						|
>>> bin(g)
 | 
						|
'0b111000'
 | 
						|
```
 | 
						|
Было 001110. Сдвинули влево на один разряд, будет 011100. Сдвинули еще раз - 111000.
 | 
						|
Слева можно добавить сколько угодно незначащих нулей, чтобы было нагляднее.
 | 
						|
 | 
						|
Сдвиг на один разряд вправо:
 | 
						|
```
 | 
						|
>>> g1 = h >> 1
 | 
						|
>>> g1
 | 
						|
7
 | 
						|
```
 | 
						|
Пояснение:
 | 
						|
```
 | 
						|
>>> bin(g1)
 | 
						|
'0b111'
 | 
						|
```
 | 
						|
Было 1110. Стало 0111. Можно откинуть незначащий ноль.
 | 
						|
 | 
						|
Сдвиг на два разряда вправо:
 | 
						|
```
 | 
						|
>>> g2 = h >> 2
 | 
						|
>>> g2
 | 
						|
3
 | 
						|
```
 | 
						|
Пояснение:
 | 
						|
```
 | 
						|
>>> bin(g2)
 | 
						|
'0b11'
 | 
						|
```
 | 
						|
Было 1110. Сдвиг вправо на один разряд: 0111. Еще на один - 0011 (Биты, выходящие за
 | 
						|
правый край, отбрасываются).
 | 
						|
 | 
						|
 | 
						|
Возьмем два двоичных числа:
 | 
						|
1011101 (в десятичной системе это 93)
 | 
						|
1100110 (в десятичной системе это 102)
 | 
						|
 | 
						|
Побитовая инверсия
 | 
						|
```
 | 
						|
>>> ~93
 | 
						|
-94
 | 
						|
>>> bin(~93)
 | 
						|
'-0b1011110'
 | 
						|
```
 | 
						|
Двоичное И
 | 
						|
```
 | 
						|
>>> bin(93&102)
 | 
						|
'0b1000100'
 | 
						|
```
 | 
						|
Двоичное ИЛИ
 | 
						|
```
 | 
						|
>>> bin(93|102)
 | 
						|
'0b1111111'
 | 
						|
```
 | 
						|
Побитовый сдвиг
 | 
						|
```
 | 
						|
>>> 93 >> 3
 | 
						|
11
 | 
						|
>>> bin(93 >> 3)
 | 
						|
'0b1011'
 | 
						|
 | 
						|
>>> 102 << 2
 | 
						|
408
 | 
						|
>>> bin (102 << 2)
 | 
						|
'0b110011000'
 | 
						|
```
 | 
						|
## Пункт 6
 | 
						|
 | 
						|
Операции при работе с последовательности
 | 
						|
 | 
						|
### Пункт 6.1
 | 
						|
 | 
						|
Конкатенация (объединение)
 | 
						|
 | 
						|
Строки
 | 
						|
```
 | 
						|
>>> 'Система '+'регулирования'
 | 
						|
'Система регулирования'
 | 
						|
```
 | 
						|
Списки
 | 
						|
```
 | 
						|
>>> ['abc','de','fg']+['hi','jkl']
 | 
						|
['abc', 'de', 'fg', 'hi', 'jkl']
 | 
						|
```
 | 
						|
Кортежи
 | 
						|
```
 | 
						|
>>> ('abc','de','fg')+('hi','jkl')
 | 
						|
('abc', 'de', 'fg', 'hi', 'jkl')
 | 
						|
```
 | 
						|
Конкатериновать словари и множества нельзя.
 | 
						|
```
 | 
						|
>>> {'one':1 , 'two':2} + {'three':3}
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#90>", line 1, in <module>
 | 
						|
    {'one':1 , 'two':2} + {'three':3}
 | 
						|
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
 | 
						|
```
 | 
						|
```
 | 
						|
>>> {1, 2} + {1, 3, 3, 4}
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#85>", line 1, in <module>
 | 
						|
    {1, 2} + {1, 3, 3, 4}
 | 
						|
TypeError: unsupported operand type(s) for +: 'set' and 'set'
 | 
						|
```
 | 
						|
### Пункт 6.2
 | 
						|
 | 
						|
Повторение (*)
 | 
						|
```
 | 
						|
>>> 'ля-'*5
 | 
						|
'ля-ля-ля-ля-ля-'
 | 
						|
 | 
						|
>>> ['ку','-']*3
 | 
						|
['ку', '-', 'ку', '-', 'ку', '-']
 | 
						|
 | 
						|
>>> ('кис','-')*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
 | 
						|
 | 
						|
Подстановка значений в строку с помощью оператора «%»
 | 
						|
 | 
						|
Подстановка возвращает новую строку, но не перезаписывает исходную.
 | 
						|
```
 | 
						|
>>> stroka='Температура = %g %s  %g'
 | 
						|
>>> stroka % (16,' меньше ',25)
 | 
						|
'Температура = 16  меньше   25'
 | 
						|
>>> stroka
 | 
						|
'Температура = %g %s  %g'
 | 
						|
```
 | 
						|
Если сообщим меньше вставок, чем требует строка:
 | 
						|
```
 | 
						|
>>> stroka % (16, "меньше")
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#113>", line 1, in <module>
 | 
						|
    stroka % (16, "меньше")
 | 
						|
TypeError: not enough arguments for format string
 | 
						|
```
 | 
						|
Если больше:
 | 
						|
```    
 | 
						|
>>> stroka1 % (2024, 21)
 | 
						|
'Сейчас 2024 год 21 века'
 | 
						|
>>> stroka1 % (2024, 21, 45)
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#118>", line 1, in <module>
 | 
						|
    stroka1 % (2024, 21, 45)
 | 
						|
TypeError: not all arguments converted during string formatting
 | 
						|
```
 | 
						|
Вот различные типы вставок для оператора %:
 | 
						|
    %s - строка
 | 
						|
    %d и %i - целое число (d - всегда десятичное, а i - десятичное или переведенное
 | 
						|
         в десятичное из другой с/с, а еще может содержать знак)
 | 
						|
    %f - число с плавающей точкой
 | 
						|
    %e - экспоненциальная форма записи числа
 | 
						|
    %g - автовыбор между e и f в зависимости от размера (очень большие и очень близкие к нулю
 | 
						|
         числа удобнее записать в экспоненциальной форме. Обычно %g будет использовать %f,
 | 
						|
         если значение находится в пределах от 1e-4 до 1e+15)
 | 
						|
    %.nf - число с плавающей точкой, но конкретным количеством знаков после запятой (пр. %.2f)
 | 
						|
```   
 | 
						|
>>> 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
 | 
						|
-7
 | 
						|
 | 
						|
>>> zz -= 3
 | 
						|
>>> zz
 | 
						|
-10
 | 
						|
```
 | 
						|
Конкатенация строк:
 | 
						|
```    
 | 
						|
>>> stroka = 'Система'
 | 
						|
>>> stroka += ' регулирования'
 | 
						|
>>> stroka
 | 
						|
'Система регулирования'
 | 
						|
```
 | 
						|
### Пункт 7.3
 | 
						|
 | 
						|
Присваивание с умножением и делением.
 | 
						|
```
 | 
						|
>>> type(zz)
 | 
						|
<class 'int'>
 | 
						|
>>> zz /= 2
 | 
						|
>>> zz
 | 
						|
-5.0
 | 
						|
>>> type(zz)
 | 
						|
<class 'float'>
 | 
						|
 | 
						|
>>> zz *= 5
 | 
						|
>>> zz
 | 
						|
-25.0
 | 
						|
 | 
						|
Для строк:
 | 
						|
>>> stroka = "mew "
 | 
						|
>>> stroka *= 3
 | 
						|
>>> stroka
 | 
						|
'mew mew mew '
 | 
						|
```
 | 
						|
### Пункт 7.4
 | 
						|
```
 | 
						|
>>> zz //= 4
 | 
						|
>>> zz
 | 
						|
-7.0
 | 
						|
```
 | 
						|
```
 | 
						|
>>> zz %= -0.45
 | 
						|
>>> zz
 | 
						|
-0.24999999999999983
 | 
						|
```
 | 
						|
### Пункт 7.5
 | 
						|
 | 
						|
Множественное присваивание
 | 
						|
 | 
						|
1) Присваивание одного значения нескольким переменным:
 | 
						|
```
 | 
						|
>>> w = v = 10
 | 
						|
>>> w
 | 
						|
10
 | 
						|
>>> v
 | 
						|
10
 | 
						|
```
 | 
						|
2) Кортежное присваивание
 | 
						|
```
 | 
						|
>>> n1, n2, n3 = (11, -3, 'all')
 | 
						|
>>> n1
 | 
						|
11
 | 
						|
>>> n2
 | 
						|
-3
 | 
						|
>>> n3
 | 
						|
'all'
 | 
						|
```
 | 
						|
Попробуем использовать другие коллекции:
 | 
						|
 | 
						|
Список
 | 
						|
```
 | 
						|
>>> x1, x2, x3 = ["a", 67, None]
 | 
						|
>>> x1
 | 
						|
'a'
 | 
						|
>>> x2
 | 
						|
67
 | 
						|
>>> x3
 | 
						|
>>> type(x3)
 | 
						|
<class 'NoneType'>
 | 
						|
```
 | 
						|
Словарь
 | 
						|
```
 | 
						|
>>> s1, s2, s3 = {"one": 1, "two": 2, "three": 3}
 | 
						|
>>> s1, s2, s3
 | 
						|
('one', 'two', 'three')
 | 
						|
```
 | 
						|
По умолчанию в словарях итерируются именно ключи. Если нужно задать значения, то это надо
 | 
						|
указать отдельно:
 | 
						|
```
 | 
						|
>>> s1, s2, s3 = {"one": 1, "two": 2, "three": 3}.values()
 | 
						|
>>> s1, s2, s3
 | 
						|
(1, 2, 3)
 | 
						|
```
 | 
						|
Если в каждую переменную надо положить именно и ключ, и значение одновременно, можно
 | 
						|
использовать метод .items(), который каждую пару ключ-значение упаковывает в отдельный
 | 
						|
кортеж
 | 
						|
```
 | 
						|
>>> y1, y2, y3 = {"one": 1, "two": 2, "three": 3}.items()
 | 
						|
>>> y1
 | 
						|
('one', 1)
 | 
						|
>>> y2
 | 
						|
('two', 2)
 | 
						|
>>> y3
 | 
						|
('three', 3)
 | 
						|
```
 | 
						|
Множество
 | 
						|
 | 
						|
Множество можно использовать для присваивания, но иногда порядок может быть иным:
 | 
						|
```
 | 
						|
>>> m1, m2, m3 = {1, 2, 3}
 | 
						|
>>> m1, m2, m3
 | 
						|
(1, 2, 3)
 | 
						|
```
 | 
						|
```
 | 
						|
>>> m1, m2, m3 = {54, 9, 0}
 | 
						|
>>> m1, m2, m3
 | 
						|
(0, 9, 54)
 | 
						|
```
 | 
						|
Строка
 | 
						|
```
 | 
						|
>>> c1, c2, c3 = "cat", "dog", "pig"
 | 
						|
>>> c1, c2, c3
 | 
						|
('cat', 'dog', 'pig')
 | 
						|
```
 | 
						|
## Пункт 8
 | 
						|
 | 
						|
Логические операции
 | 
						|
 | 
						|
### Пункт 8.1
 | 
						|
 | 
						|
Используем операции сравнения на ранее созданных переменных:
 | 
						|
```
 | 
						|
>>> w == v
 | 
						|
True
 | 
						|
>>> w != v
 | 
						|
False
 | 
						|
>>> w < v
 | 
						|
False
 | 
						|
>>> w > v
 | 
						|
False
 | 
						|
>>> w <= v
 | 
						|
True
 | 
						|
>>> w >= v
 | 
						|
True
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
### Пункт 8.2
 | 
						|
 | 
						|
Проверка наличия заданного элемента
 | 
						|
 | 
						|
В множестве:
 | 
						|
```
 | 
						|
>>> mnoz1={'pen','book','pen','iPhone','table','book'}
 | 
						|
>>> 'book' in mnoz1
 | 
						|
True
 | 
						|
>>> 'cap' in mnoz1
 | 
						|
False
 | 
						|
```
 | 
						|
В словаре:
 | 
						|
```
 | 
						|
>>> dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
 | 
						|
>>> '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
 | 
						|
 | 
						|
Создание больших логических выражений
 | 
						|
```
 | 
						|
>>> a = 17
 | 
						|
>>> b = 6
 | 
						|
>>> (a >= b) and ('book' in mnoz1) and not ('Pskov' in dic1)
 | 
						|
True
 | 
						|
```
 | 
						|
Собственные примеры:
 | 
						|
```
 | 
						|
>>> ((per1 + 50) in dic1.values()) and not per2 or 'Tula' in dic1
 | 
						|
True
 | 
						|
 | 
						|
>>> not(len(dic1) == 3) or (sum(dic1.values()) > 300) or ('ITAE' in dct1['Depart'])
 | 
						|
False
 | 
						|
```
 | 
						|
### Пункт 8.4
 | 
						|
 | 
						|
Проверка ссылок переменных на один и тот же объект
 | 
						|
 | 
						|
Проверим is для разных объектов неизменяемого типа с одним значением
 | 
						|
```
 | 
						|
>>> v = w = 10
 | 
						|
>>> w is v
 | 
						|
True
 | 
						|
```
 | 
						|
Попробуем создать два списка с одинаковым значением:
 | 
						|
```
 | 
						|
>>> w1 = ['A', 'B']
 | 
						|
>>> v1 = ['A', 'B']
 | 
						|
>>> w1 is v1
 | 
						|
False
 | 
						|
```
 | 
						|
Но при этом:
 | 
						|
```
 | 
						|
>>> w1 == v1
 | 
						|
True
 | 
						|
```
 | 
						|
--Почему так происходит?--
 | 
						|
Оператор is проверяет, ссылаются ли объекты на один и тот же адрес в памяти. Переменные
 | 
						|
целочисленного типа были созданы в одну строку и имеют один и тот же адрес в памяти.
 | 
						|
Словари были созданы в разных строках, и адреса они разные, т.е. они ссылаются на разные
 | 
						|
участки в памяти, поэтому is возвращает False. Можно убедиться в этом наглядно: 
 | 
						|
```
 | 
						|
>>> id(w)
 | 
						|
140732520269000
 | 
						|
```
 | 
						|
```
 | 
						|
>>> id(v)
 | 
						|
140732520269000
 | 
						|
```
 | 
						|
Видно, что адрес памяти объекта одинаковый.
 | 
						|
 | 
						|
Теперь проверим для списков:
 | 
						|
```
 | 
						|
>>> id(w1)
 | 
						|
1342934277312
 | 
						|
```
 | 
						|
```
 | 
						|
>>> id(v1)
 | 
						|
1342934274048
 | 
						|
```
 | 
						|
Видно, что адреса разные.
 | 
						|
 | 
						|
 | 
						|
## Пункт 9
 | 
						|
 | 
						|
Операции с объектами, выполняемые с помощью методов
 | 
						|
```
 | 
						|
>>> stroka='Микропроцессорная система управления'
 | 
						|
>>> dir(stroka)
 | 
						|
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__',
 | 
						|
 '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__',
 | 
						|
 '__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('пр')
 | 
						|
5
 | 
						|
```
 | 
						|
Поиск количества вхождений подстроки
 | 
						|
```
 | 
						|
>>> stroka.count("с")
 | 
						|
4
 | 
						|
```
 | 
						|
У обоих методов в качестве доп. аргумента можно указать срез.
 | 
						|
 | 
						|
Замена подстроки
 | 
						|
```
 | 
						|
>>> stroka.replace(' у',' автоматического у')
 | 
						|
'Микропроцессорная система автоматического управления'
 | 
						|
```
 | 
						|
Это возвращает новую строку, но не перезаписывает исходную.
 | 
						|
 | 
						|
Разделение по separator'у
 | 
						|
```
 | 
						|
>>> spis22=stroka.split(' ')
 | 
						|
>>> spis22
 | 
						|
['Микропроцессорная', 'система', 'управления']
 | 
						|
```
 | 
						|
Все буквы заглавные
 | 
						|
```
 | 
						|
>>> stroka.upper()
 | 
						|
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
 | 
						|
```
 | 
						|
Все буквы строчные
 | 
						|
```
 | 
						|
>>> stroka.lower()
 | 
						|
'микропроцессорная система управления'
 | 
						|
```
 | 
						|
Собрать строку из элементов списка
 | 
						|
```
 | 
						|
>>> stroka3=" ".join(spis22)
 | 
						|
>>> stroka3
 | 
						|
'Микропроцессорная система управления'
 | 
						|
```
 | 
						|
В кавычках указывается разделитель, в скобках после join - объект, из которого собираем
 | 
						|
строку
 | 
						|
 | 
						|
Разделение по первой входящей подстроке
 | 
						|
```
 | 
						|
>>> stroka3.partition("с")
 | 
						|
('Микропроце', 'с', 'сорная система управления')
 | 
						|
```
 | 
						|
Разделение по последней входящей подстроке
 | 
						|
```
 | 
						|
>>> stroka3.rpartition("с")
 | 
						|
('Микропроцессорная си', 'с', 'тема управления')
 | 
						|
```
 | 
						|
Форматирование
 | 
						|
```
 | 
						|
>>> strk1='Момент времени {}, значение = {}'
 | 
						|
>>> strk1
 | 
						|
'Момент времени {}, значение = {}'
 | 
						|
>>> strk1.format(1,89.7)
 | 
						|
'Момент времени 1, значение = 89.7'
 | 
						|
```
 | 
						|
Можно указать порядок:
 | 
						|
```
 | 
						|
>>> strk2='Момент времени {1}, значение = {0}:{2}
 | 
						|
>>> strk2
 | 
						|
'Момент времени {1}, значение = {0}:{2}'
 | 
						|
>>> strk2.format(36.7,2,'норма!')
 | 
						|
'Момент времени 2, значение = 36.7:норма!'
 | 
						|
```
 | 
						|
Или можно подставить имена аргументов-вставок, и тогда порядок подстановки может быть
 | 
						|
произвольным:
 | 
						|
```
 | 
						|
>>> strk3='Момент времени {num}, значение = {znch}'
 | 
						|
>>> strk3
 | 
						|
'Момент времени {num}, значение = {znch}'
 | 
						|
>>> strk3.format(znch=89.7,num=2)
 | 
						|
'Момент времени 2, значение = 89.7'
 | 
						|
```
 | 
						|
### Пункт 9.2
 | 
						|
 | 
						|
Методы списков
 | 
						|
```
 | 
						|
>>> spsk = [12, "kitten", (1, 2), "a", 56.78]
 | 
						|
```
 | 
						|
Удаление элемента по индексу и сдвиг последующих влево
 | 
						|
```
 | 
						|
>>> spsk.pop(2)
 | 
						|
(1, 2)
 | 
						|
>>> spsk
 | 
						|
[12, 'kitten', 'a', 56.78]
 | 
						|
```
 | 
						|
Вставка элемента в конец
 | 
						|
```
 | 
						|
>>> spsk.append('c')
 | 
						|
>>> spsk
 | 
						|
[12, 'kitten', 'a', 56.78, 'c']
 | 
						|
```
 | 
						|
Можно вставить только один элемент, иначе TypeError
 | 
						|
 | 
						|
Вставка элемента в конкретное место по индексу
 | 
						|
```
 | 
						|
>>> spsk.insert(2,'a')
 | 
						|
>>> spsk
 | 
						|
[12, 'kitten', 'a', 'a', 56.78, 'c']
 | 
						|
```
 | 
						|
Подсчет количества элементов по значению
 | 
						|
```
 | 
						|
>>> spsk.count('a')
 | 
						|
2
 | 
						|
```
 | 
						|
### Пункт 9.3
 | 
						|
 | 
						|
Методы кортежей
 | 
						|
 | 
						|
Кортежи неизменяемы, поэтому методов, связанных с удалением или добавлением элементов, нет.
 | 
						|
Есть два:
 | 
						|
```
 | 
						|
>>> cor = (11, "oopsie", "doopsie", 64.9, 5+7j)
 | 
						|
```
 | 
						|
Подсчет количества элементов по значению
 | 
						|
```
 | 
						|
>>> cor.count(11)
 | 
						|
1
 | 
						|
```
 | 
						|
Поиск индекса первого вхождения
 | 
						|
 | 
						|
Если не найдено, то ValueError
 | 
						|
```
 | 
						|
>>> cor.index(64.9)
 | 
						|
3
 | 
						|
>>> cor.index("nothing")
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#316>", line 1, in <module>
 | 
						|
    cor.index("nothing")
 | 
						|
ValueError: tuple.index(x): x not in tuple
 | 
						|
```
 | 
						|
### Пункт 9.4
 | 
						|
 | 
						|
Методы словарей
 | 
						|
 | 
						|
Создание поверхностной копии
 | 
						|
 | 
						|
Создается копия, но новые значения не создаются с нуля, а просто ссылаются на предыдущие:
 | 
						|
```
 | 
						|
>>> newdi = di.copy()
 | 
						|
>>> newdi
 | 
						|
{'key1': 1, 'key2': 'val2', 'key3': 34.6, 'key4': 'f', 'key5': False}
 | 
						|
```
 | 
						|
Возвращение значения по ключу
 | 
						|
```
 | 
						|
>>> di.get("key2")
 | 
						|
'val2'
 | 
						|
```
 | 
						|
Если такого ключа нет, возвращается None
 | 
						|
```
 | 
						|
>>> print(di.get("key77"))
 | 
						|
None
 | 
						|
```
 | 
						|
Возвращение кортежей из пар ключ-значение
 | 
						|
```
 | 
						|
>>> di.items()
 | 
						|
dict_items([('key1', 1), ('key2', 'val2'), ('key3', 34.6), ('key4', 'f'), ('key5', False)])
 | 
						|
>>> type(di.items())
 | 
						|
<class 'dict_items'>
 | 
						|
```
 | 
						|
Возвращение объекта только из ключей
 | 
						|
```
 | 
						|
>>> di.keys()
 | 
						|
dict_keys(['key1', 'key2', 'key3', 'key4', 'key5'])
 | 
						|
```
 | 
						|
Возвращение объекта только из значений
 | 
						|
```
 | 
						|
>>> di.values()
 | 
						|
dict_values([1, 'val2', 34.6, 'f', False])
 | 
						|
```
 | 
						|
Пояснение:
 | 
						|
    Возвращаются объекты dict_keys, dict_values, dict_items, и они - объекты-итераторы. Они
 | 
						|
    ссылаются на адреса ключей или значений в памяти, но не хранят значения. Также эти объекты
 | 
						|
    автоматически обновляются при обновлении словаря. Например, добавим в словарь пару:
 | 
						|
```
 | 
						|
    >>> di["key6"] = 546
 | 
						|
    >>> di
 | 
						|
    {'key1': 1, 'key2': 'val2', 'key3': 34.6, 'key4': 'f', 'key5': False, 'key6': 546}
 | 
						|
```
 | 
						|
    Теперь в отдельный объект положим dict_keys:
 | 
						|
```
 | 
						|
    >>> dikeys = di.keys()
 | 
						|
    >>> dikeys
 | 
						|
    dict_keys(['key1', 'key2', 'key3', 'key4', 'key5', 'key6'])
 | 
						|
```
 | 
						|
    Удалим с помощью метода .popitem() последний добавленный элемент:
 | 
						|
```
 | 
						|
    >>> di.popitem()
 | 
						|
    ('key6', 546)
 | 
						|
```
 | 
						|
    Вот как теперь выглядит словарь:
 | 
						|
```
 | 
						|
    >>> di
 | 
						|
    {'key1': 1, 'key2': 'val2', 'key3': 34.6, 'key4': 'f', 'key5': False}
 | 
						|
```
 | 
						|
    Вот как выглядит dikeys:
 | 
						|
```
 | 
						|
    >>> dikeys
 | 
						|
    dict_keys(['key1', 'key2', 'key3', 'key4', 'key5'])
 | 
						|
```
 | 
						|
Полное очищение словаря
 | 
						|
```
 | 
						|
>>> newdi.clear()
 | 
						|
>>> newdi
 | 
						|
{}
 | 
						|
```
 | 
						|
Удаление ключа и возвращение значения
 | 
						|
```
 | 
						|
>>> di.pop("key3")
 | 
						|
34.6
 | 
						|
>>> di
 | 
						|
{'key1': 1, 'key2': 'val2', 'key4': 'f', 'key5': False}
 | 
						|
```
 | 
						|
Методы множеств
 | 
						|
```
 | 
						|
>>> se = {1, "val2", 34.6, "f", False, 546}
 | 
						|
>>> se
 | 
						|
{False, 1, 34.6, 546, 'f', 'val2'}
 | 
						|
```
 | 
						|
Добавление элемента
 | 
						|
```
 | 
						|
>>> se.add(5+6j)
 | 
						|
>>> se
 | 
						|
{False, 1, 34.6, 546, (5+6j), 'f', 'val2'}
 | 
						|
```
 | 
						|
Создание поверхностной копии
 | 
						|
```
 | 
						|
>>> newse = se.copy()
 | 
						|
>>> newse
 | 
						|
{False, 1, 34.6, 546, (5+6j), 'f', 'val2'}
 | 
						|
```
 | 
						|
Удаление элемента по значению с KeyError при отсутствии
 | 
						|
```
 | 
						|
>>> se.remove(1)
 | 
						|
>>> se
 | 
						|
{False, 34.6, 546, (5+6j), 'f', 'val2'}
 | 
						|
>>> se.remove(90000)
 | 
						|
Traceback (most recent call last):
 | 
						|
  File "<pyshell#348>", line 1, in <module>
 | 
						|
    se.remove(90000)
 | 
						|
KeyError: 90000
 | 
						|
```
 | 
						|
Удаление элемента по значению с возвратом None при отсутствии
 | 
						|
```
 | 
						|
>>> se.discard("f")
 | 
						|
>>> se.discard(90000)
 | 
						|
>>> print(se.discard(90000))
 | 
						|
None
 | 
						|
```
 | 
						|
Очищение множества
 | 
						|
```
 | 
						|
>>> newse.clear()
 | 
						|
>>> newse
 | 
						|
set()
 | 
						|
```
 | 
						|
Удаление и возвращение случайного элемента из множества
 | 
						|
```
 | 
						|
>>> se.pop()
 | 
						|
False
 | 
						|
>>> se
 | 
						|
{34.6, 546, (5+6j), 'val2'}
 | 
						|
```
 | 
						|
 | 
						|
Добавление элементов
 | 
						|
```
 | 
						|
>>> se.update({True, "kekeke"})
 | 
						|
>>> se
 | 
						|
{True, 34.6, 546, 'val2', (5+6j), 'kekeke'}
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 |