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

31 KiB

Отчет по теме 3

Володин Денис, А-02-23

Пункт 1.

Рабочая среда настроена на нахождение в нужной директории:

>>> import os
>>> os.chdir(r'C:\Users\denvo\OneDrive\Рабочий стол\python-labs\TEMA3')

Пункт 2.

Пункт 2.1

Преобразование в логический тип (bool())

Различные варианты:

>>> logiz1=bool(56)
>>> logiz1
True
>>> logiz2=bool(0)
>>> logiz2
False
>>> logiz3=bool("Beta")
>>> logiz3
True
>>> logiz4=bool("")
>>> logiz4
False
>>> logiz5=bool(" ")
>>> logiz5
True
>>> logiz6=bool(-1)
>>> logiz6
True
>>> logiz7=bool(None)
>>> logiz7
False
>>> logiz8=bool([])
>>> logiz8
False
>>> logiz8=bool([" "])
>>> logiz8
True

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 ожидает, что ей сообщат строку, похожую на тип int (только цифры, может быть знак в начале). Здесь есть точка, поэтому вознакает несоответствие ожидаемого формата фактическому. Можно сначала строку перевести в число с плавающей точкой, а потом уже в int.

Еще варианты:

>>> tt6=int("+43")
>>> tt6
43
>>> tt6=int("aaa")
Traceback (most recent call last):
  File "<pyshell#37>", line 1, in <module>
    tt6=int("aaa")
ValueError: invalid literal for int() with base 10: 'aaa'
>>> tt6=int("aaa", 16)
>>> tt6
2730

Преобразование в вещественное число:

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

Видно, что результат выглядит неточно. Это связанно с тем, что вещественные числа в python внутри представляются как двоичные, но не всегда вещественное число можно представить как двоичное абсолютно точно, из-за этого возникают такие неточности

>>> 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.

В целом, можно сказать, что в Python двоичная инверсия делает из числа n число -(n+1).

Пункт 5.2

Двоичное "И" (&)

>>> bin(7&9)
'0b1'
>>> bin(7&8)
'0b0'

Пояснение: 7 в двоичной системе счисления: 0111 9 в двоичной системе счисления: 1001 Совпадение единиц только в первом разряде, поэтому итог - 0001 или просто 1 8 в двоичной системе счисления: 1000 Совпадений единиц нет, итог - 0000 или просто 0

Пункт 5.3

Двоичное "ИЛИ" (|)

>>> bin(7|9)
'0b1111'
>>> bin(7|8)
'0b1111'
>>> bin (14|5)
'0b1111'

Пояснение: 7 в двоичной системе счисления: 0111 9 в двоичной системе счисления: 1001 Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов есть единица, поэтому итог - 1111 8 в двоичной системе счисления: 1000 Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов есть единица, поэтому итог - 1111 14 в двоичной системе счисления: 1110 5 в двоичной системе счисления: 0101 Возвращается 1, если хотя бы в одном из попарно одинаковых разрядов есть единица, поэтому итог - 1111

Пункт 5.4

Двоичный XOR (^) (возвращается единица, если оба разряда разные)

>>> bin(14^5)
'0b1011'

Пояснение: 14 в двоичной системе счисления: 1110 5 в двоичной системе счисления: 0101 Возвращается 1, если оба разряда разные, поэтому итог - 1011 или 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'  
>>> 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'
>>> bin(93^102)
'0b111011' 
>>> 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
>>> stroka % (16,' меньше ',25,15)
Traceback (most recent call last):
  File "<pyshell#118>", line 1, in <module>
    stroka % (16,' меньше ',25,15)
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

Множественное присваивание

>>> w = v = 10
>>> w
10
>>> v
10
>>> 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)
>>> 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
>>> 0 == False
True
>>> 1 == True
True
>>> 0 == None
False
>>> None == None
True
>>> 5 != 5.0000
False
>>> inf = float ("Infinity")
>>> inf1 = float("-inf")
>>> inf > -inf
True
>>> inf2 = float ("Infinity")
>>> inf == inf2
True
>>> [1, 2, 3] == (1, 2, 3)
False
>>> "9" == 9
False
>>> None > 0
Traceback (most recent call last):
  File "<pyshell#198>", line 1, in <module>
    None > 0
TypeError: '>' not supported between instances of 'NoneType' and 'int'
>>> '100' < 100
Traceback (most recent call last):
  File "<pyshell#200>", line 1, in <module>
    '100' < 100
TypeError: '<' not supported between instances of 'str' and 'int'

Пункт 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
>>> a = [1, 2, 3]
>>> b = a
>>> b
[1, 2, 3]
>>> a == b
True
>>> a in b
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)
2290989558352
>>> id(v)
2290989558352
>>> id(w1)
2291031104768
>>> id(v1)
2291031109824
>>> a = 15
>>> b = 15
>>> a is b
True
>>> id(a)
2290989558512
>>> id(b)
2290989558512

Это связано с тем, что python - очень высокоуровневый язык, возможности в плане оперирования памятью сведены к минимуму, и иногда использование памяти оптимизировано. Например, числа от -5 до 256 python подвергает интернированию, т.е. делает так, чтобы они ссылались на один участок памяти (конкретно в cpython). Но с числами, не попадающими в этот диапазон, это не работает.

>>> aaa = 567
>>> bbb = 567
>>> aaa is bbb
False
>>> a = b = 567
>>> a is b
True
>>> aa = ()
>>> bb = ()
>>> aa is bb
True

Пункт 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(' у',' автоматического у')
'Микропроцессорная система автоматического управления'
>>> spis22=stroka.split(' ')
>>> spis22
['Микропроцессорная', 'система', 'управления']
>>> stroka.upper()
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
>>> stroka.lower()
'микропроцессорная система управления'
>>> stroka3=" ".join(spis22)
>>> stroka3
'Микропроцессорная система управления'
>>> 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]
>>> 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)
(1, 2)
>>> spsk
[12, 'kitten', 'a', 56.78]
>>> spsk.append('c')
>>> spsk
[12, 'kitten', 'a', 56.78, 'c']
>>> 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)
>>> dir(cor)
['__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']
>>> cor.count(11)
1
>>> 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}
>>> dir(newdi)
['__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']
>>> di.get("key2")
'val2'
>>> 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}
>>> dikeys = di.keys()
>>> dikeys
dict_keys(['key1', 'key2', 'key3', 'key4', 'key5', 'key6'])
>>> di.popitem()
('key6', 546)
>>> di
{'key1': 1, 'key2': 'val2', 'key3': 34.6, 'key4': 'f', 'key5': False}
>>> 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}
>>> dir(se)
['__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']
>>> 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'}
>>> 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
>>> 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, (5+6j), 'val2', 'kekeke'}