Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

33 KiB

Тема 3

1. Запуск IDLE

2. Преобразование простых базовых типов объектов.

2.1. Преобразование в логический тип с помощью функции bool(<Объект>).

Примеры использования:

>>>logiz1 = bool(56)
>>>logiz1
True
>>>logiz2 = bool(0)
>>>logiz2
False
>>>logiz3 = bool("Beta")
>>>logiz3
True
>>>logiz4 = bool(" ")
>>>logiz4
True

### 2.2. Преобразование в целое десятичное число объекта с заданной системой счисления. осуществляется с помощью функции int(<Объект>[,<Система счисления, в которой определен объект>]). По умолчанию система счисления принимается десятичной.
Примеры использования:

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#16>", line 1, in tt5 = int("98,76") ValueError: invalid literal for int() with base 10: '98,76'

Как видно, выводится диагностическое сообщение. Выводится оно по причине того, что заданное число вещественное(float), а ожидается значение типа "int".

Преобразование целых чисел или строк символов в вещественное число – с помощью функции float(<Объект>).
Примеры преобразований:

flt1 = float(789) flt1 789.0 flt2 = float(-6.78e2) flt2 -678.0 flt3 = float("Infinity") flt3 inf flt4 = float("-inf") flt4 -inf


### 2.3.  Преобразование десятичных чисел в другие системы счисления:

hh=123 hh 123 dv1=bin(hh) #Преобразование в строку с двоичным представлением dv1 '0b1111011' vos1=oct(hh) # Преобразование в строку с восьмеричным представлением vos1 '0o173' shs1=hex(hh) # Преобразование в строку с шестнадцатеричным представлением shs1 '0x7b'

Выполним обратные преобразования объектов dv1, vos1, shs1:

int(dv1,2) 123 int(vos1, 8) 123 int(shs1, 16) 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}"

### 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']

Инструкция, обеспечивающую создание из того же словаря списка с другими его частями:

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')

### 3.4. Удаление объектов.
Очистить оперативную память от ранее созданных объектов можно с помощью инструкции del.
Пример:

del strk5, kort8 strk5
Traceback (most recent call last): File "<pyshell#77>", line 1, in strk5 NameError: name 'strk5' is not defined. Did you mean: 'strk1'? kort8
Traceback (most recent call last): File "<pyshell#78>", line 1, in kort8 NameError: name 'kort8' is not defined. Did you mean: 'kort7'?


Создание строки со своей фамилией и инициалами, преобразование её в список, затем список – в кортеж и, наконец, кортеж – в строку. .

fam = list('Melnikov DM')
fam
['M', 'e', 'l', 'n', 'i', 'k', 'o', 'v', ' ', 'D', 'M'] kort = tuple(fam)
kort
('M', 'e', 'l', 'n', 'i', 'k', 'o', 'v', ' ', 'D', 'M') strk = str(kort)
strk
"('M', 'e', 'l', 'n', 'i', 'k', 'o', 'v', ' ', 'D', 'M')"


## 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! a 3.9555555555555557 type(a)
<class 'float'>

### 4.4.  Деление с округлением вниз (//). 
Здесь результат может быть целым или вещественным. В нижеследующих операциях определите тип результата.

b=178//45 #Деление двух целых чисел b
3 type(b)
<class 'int'> c=-24.6//12.1 #Деление двух вещественных чисел
c
-3.0 type(c)
<class 'float'> zz1 = 78.4 / 16
zz1
4.9 type(zz1)
<class 'float'> zz2 = 78.4 // 16
zz2
4.0 type(zz2)
<class 'float'> zz3 = 78 // 16
zz3
4 type(zz3) <class 'int'>


### 4.5.  Получение остатка от деления (%).

148 % 33 #Остаток от деления двух целых чисел 16 12.6 % 3.8 #Остаток от деления двух вещественных чисел 1.2000000000000002 1.2000000000000002 36 % 12
0 36.98 % 23.56
13.419999999999998


### 4.6.  Возведение в степень (**). 

143
2744 e=2.7
3.6 #Вещественное число возводится в вещественную степень e
35.719843790663525


Попробуем проделать арифметические операции над комплексными числами. Создадим два
комплексных числа

comp1 = (5 + 3j)
comp1
(5+3j) type(comp1)
<class 'complex'> comp2 = (10 - 5j)
comp2
(10-5j) type(comp2)
<class 'complex'>

Сложение:

comp1 + comp2
(15-2j)

Вычитание:

comp1 - comp2
(-5+8j)

Умножение:

comp1 * comp2
(65+5j)

Деление:

comp1 / comp2
(0.28+0.44j)

Целочисленное деление:

comp1 // comp2
Traceback (most recent call last): File "<pyshell#129>", line 1, in comp1 // comp2 TypeError: unsupported operand type(s) for //: 'complex' and 'complex' comp1 // 2
Traceback (most recent call last): File "<pyshell#130>", line 1, in comp1 // 2 TypeError: unsupported operand type(s) for //: 'complex' and 'int'

Как видим, целочисленное деление нельзя применять к комплексным числам.

Взятие остатка от деления:

comp1 % comp2 Traceback (most recent call last): File "<pyshell#131>", line 1, in comp1 % comp2 TypeError: unsupported operand type(s) for %: 'complex' and 'complex' comp1 % 2
Traceback (most recent call last): File "<pyshell#132>", line 1, in comp1 % 2 TypeError: unsupported operand type(s) for %: 'complex' and 'int'

Как видим, взятие остатка от деления нельзя применять к комплексным числам.

Возведение в степень:

comp1 ** comp2
(-652921189.7700557+180781145.7454619j) comp1**5
(-6100+2868j)


## 5. Операции с двоичными представлениями целых чисел.

### 5.1.  Двоичная инверсия (~).
Значение каждого бита в представлении числа заменяется на противоположное значение (0 на 1, 1 на 0).

dv1 = 9
dv2 = ~dv1
dv2
-10 bin(dv1)
'0b1001' bin(dv2)
'-0b1010'

### 5.2.  Двоичное «И» (&) – побитовое совпадение двоичных представлений чисел

bin(7&9)
'0b1'

Совпадение единиц только в первом разряде, поэтому итог - 0001 или просто 1

bin(7&8)
'0b0'

Совпадений единиц нет, итог - 0000 или просто 0

### 5.3.  Двоичное «ИЛИ» (|) 
Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда равны 0

bin(7|9) # 111 или 1001 = 1111 '0b1111' bin(7|8) # 111 или 1000 = 1111 '0b1111' bin(14|5) # 1110 или 0101 = 1111 '0b1111'

### 5.4. Двоичное «исключающее ИЛИ»(^) 

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

bin(14^5) # 1110 исключающее или 0101 = 1011 '0b1011'

Значение в десятичном представление:

14^5
11


### 5.5.  Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева.

h=14 #Двоичное представление = 1110 bin(h)
'0b1110' g=h<<2 # Новое двоичное представление = 111000 g
56 bin(g)
'0b111000' g1=h>>1 # Новое двоичное представление = 0111 g1
7 bin(g1)
'0b111' g2=h>>2 # Новое двоичное представление = 0011 g2
3 bin(g2)
'0b11'

Придумайте два двоичных числа, не менее чем с 7 знаками, и попробуйте выполнить с ними разные операции.

Возьмем два двоичных числа:
1011001 (в десятичной системе это 89)
10001001 (в десятичной системе это 137)

1. Двоичная инверсия

~89
-90 bin(~89)
'-0b1011010'


2. Двоичное "И"

bin(89 & 137)
'0b1001'


3. Двоичное "ИЛИ"

bin(89 | 137)
'0b11011001'


4. Двоичное "исключающее ИЛИ"

bin(89^137)
'0b11010000'


5. Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева.

89 >> 2
22 bin(89 >> 2)
'0b10110' 137 << 3
1096 bin(137 << 3)
'0b10001001000'


## 6. Операции при работе с последовательностями (строками, списками, кортежами).
        
### 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 раза ('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-')

Создание списка со 100 отсчетами сигнала-ступеньки:

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' 'Температура = %g %s %g' stroka % (16,' меньше ',25) 'Температура = %g %s %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 /= 2
zz
-5.0 zz*= 5
zz
-25.0 per = 2
per*=10
per
20


### 7.4. Операции деления с округлением вниз (//=), получения остатка от деления (%=) и возведения в степень(**=).

zz //= 2
zz
-13.0 zz %= -2
zz
-1.0 per **= 4
per
160000


### 7.5.  Множественное присваивание
    w=v=10  # Переменным присваивается одно и то же значение
    n1,n2,n3=(11,-3,'all')  #Значения переменных берутся из кортежа
Самостоятельно проверьте, можно ли вместо кортежа справа использовать строку, список, словарь, множество?
1) Присваивание одного значения двум переменным

w = v =10
w, v
(10, 10)

2) Присваивание кортежем 

n1, n2, n3 = (11, -3, 'all')
n1, n2, n3
(11, -3, 'all')

3) Присваивание строкой

a1, a2, a3 = 'red', 'black' , 'blue'
a1, a2, a3
('red', 'black', 'blue')

4) Присваивание списком

b1, b2, b3 = ["s", 67, None]
b1, b2, b3
('s', 67, None) b3
type(b3)
<class 'NoneType'>

5) Присваивание словарем

c1, c2, c3 = {"one": 1, "two": 2, "three": 3}
c1, c2, c3
('one', 'two', 'three')

По умолчанию в словарях итерируются именно ключи. Если нужно задать значения, надо
указать дополнительно ".value":

c1, c2, c3 = {"one": 1, "two": 2, "three": 3}.values()
c1, c2, c3
(1, 2, 3)

Если в каждую переменную надо положить именно и ключ, и значение одновременно, можно
использовать метод .items(), который каждую пару(ключ-значение) распределяет в отдельный
кортеж

d1, d2, d3 = {"one": 1, "two": 2, "three": 3}.items()
d1
('one', 1) d2
('two', 2) d3
('three', 3)



6) Присваивание множеством

m1, m2, m3 = {100, 23, 59}
m1, m2, m3
(59, 100, 23)


## 8. Логические операции 

### 8.1.  Операции сравнение: равенство (==), не равно (!=), меньше (<), больше (>), меньше или равно (<=), больше или равно (>=) 

w == v
True w != v
False w < v
False w > v
False w >= v
True

Другие примеры:

0 == False
True 0 == True
False 100 != 1000
True 1200 > 100
True 1200 < 1000
False 1200 >= 1000
True


### 8.2.  Проверка наличия заданного элемента в последовательности или во множестве, а также  проверка наличия ключа в словаре (in).

Операции с множеством 

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']} 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

Собственные примеры:

((145) in dic1.values()) and not ('Rostov' in dic1)
True not(len(dic1) == 3) or (sum(dic1.values()) > 300) or ('ITAE' in dct1['Depart'])
False

### 8.4. Проверка ссылок переменных на один и тот же объект (is).

w=v=10  #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти

w is v True w1 = ['A', 'B'] v1 = ['A', 'B'] w1 is v1

Но при этом:

False

w1 == v1
True

Основная разница "==" и "is":
- is проверяет, являются ли две переменные ссылками на один и тот же объект в памяти
- == проверяет, равны ли значения объектов (содержимое одинаковое)
Переменные целочисленного типа были созданы в одну строку и имеют один и тот же адрес в памяти. `Словари были созданы в разных строках, и адреса разные, т.е. они ссылаются на разные участки в памяти, поэтому is возвращает False.

## 9. Операции с объектами, выполняемые с помощью методов.
Полный список всех атрибутов любого объекта можно получить с использованием функции dir, например,

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('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1 5 stroka.count("с") #Подсчет числа вхождений строки “с” в stroka 4 stroka.replace(' у',' автоматического у') 'Микропроцессорная система автоматического управления' spis22=stroka.split(' ') #Возвращает список подстрок, между которыми в строке стоит заданный разделитель spis22
['Микропроцессорная', 'система', 'управления'] stroka.upper() #Возвращает строку со всеми заглавными буквами stroka3=" ".join(spis22) #Возвращает строку, собранную из элементов списка stroka3
'Микропроцессорная система управления' stroka3.partition("с") #Возвращает кортеж с результатами поиска «с» слева ('Микропроце', 'с', 'сорная система управления') stroka3.rpartition("с") #Возвращает кортеж с результатами поиска «с» справа ('Микропроцессорная си', 'с', 'тема управления')

Изучим метод format. 

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.format(znch=89.7,num=2) 'Момент времени 2, значение = 89.7'

В этом варианте порядок аргументов не обязательно соответствует порядку вставок в строке.

### 9.2. Методы для работы со списками. 
Создайте произвольный список spsk, не менее чем с 5 элементами. Отобразите его атрибуты.
Последовательно обратитесь к методам этого списка с отображением каждый раз полученного списка:

spsk = ["blue", 163, (1, 2), "green", 78.69] #Создаем список
spsk.pop(2) #Удаляем второй элемент из списка
(1, 2) #Удаленный элемент spsk
['blue', 163, 'green', 78.69] spsk.append('c') #Добавляем элемент в список, по умолчанию добавляется в конец
spsk
['blue', 163, 'green', 78.69, 'c'] spsk.insert(2, 'a') #Добавление элемента в список с индексом два
spsk
['blue', 163, 'a', 'green', 78.69, 'c'] spsk.count('a') #Подсчет элементов 'a' в списке
1


### 9.3. Создание кортежа и изучение создания его методов.

cort = ('abc', 52.3, 'a', 167, 3 + 2j) dir(cort)
['add', 'class', 'class_getitem', 'contains', 'delattr', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'getitem', 'getnewargs', 'gt', 'hash', 'init', 'init_subclass', 'iter', 'le', 'len', 'lt', 'mul', 'ne', 'new', 'reduce', 'reduce_ex', 'repr', 'rmul', 'setattr', 'sizeof', 'str', 'subclasshook', 'count', 'index'] cort.count('a')
1 cort.index(3+2j)
4

Благодаря функции dir видим, что кортеж имеет меньше атрибутов чем список.

### 9.4. Методы словарей и множеств.
- Методы словарей
Возьмем уже ранее использованный словарь dic1

dic1
{'Saratov': 145, 'Orel': 56, 'Vologda': 45} dic1.keys() # Возвращение объектов, состоящих только из ключей.
dict_keys(['Saratov', 'Orel', 'Vologda']) dir(dic1)
['class', 'class_getitem', 'contains', 'delattr', 'delitem', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'getitem', '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'] dic1.items() #Возвращение кортежей из пар ключ-значение
dict_items([('Saratov', 145), ('Orel', 56), ('Vologda', 45)]) dic1.get("Saratov") #Возвращение значения по ключу
145 dic1.values() #Возвращение объекта только из значений
dict_values([145, 56, 45]) dic1["key4"] = 49 #Вызов значения по ключу
dic1
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'key4': 49} dic1_k = dic1.keys() #Создание отдельного объекта, чтобы положить в него dict_keys
dic1_k
dict_keys(['Saratov', 'Orel', 'Vologda', 'key4']) dic1.popitem() #Удаление последнего добавленного элемента
('key4', 49) dic1
{'Saratov': 145, 'Orel': 56, 'Vologda': 45} dic1_k
dict_keys(['Saratov', 'Orel', 'Vologda']) dic1.pop("Orel") #Удаление ключа и возвращение значения
56

- Методы множеств

mn = {1, "per", 35.8, "red", True, 153} #Создаем множество mn
{1, 35.8, 'per', 153, 'red'} dir(mn)
['and', 'class', 'class_getitem', 'contains', 'delattr', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', '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'] mn.add(6+3j) #Добавление элемента в конец множества
mn
{1, 35.8, 'per', 153, 'red', (6+3j)} mn.remove(1) #Удаление элемента по значению
mn
{35.8, 'per', 153, 'red', (6+3j)} mn.discard("red") #Удаление элемента по значению с возвратом None при отсутствии
mn
{35.8, 'per', 153, (6+3j)} {35.8, 'per', 153, (6+3j)} print(mn.discard(1000))
None mn.pop() #Удаление и возвращение случайного элемента из множества
35.8 mn
{'per', 153, (6+3j)} mn.update({63, "klumba"}) #Добавление элементов mn {'klumba', 'per', 153, 63, (6+3j)}


## 10. Сохранение созданного текстового файла протокола в своем рабочем каталоге. Завершение сеанса работы с IDLE.