38 KiB
Отчет по теме 3
Цель темы: изучение способов использования объектов разных типов.
Терехов Фёдор Валерьевич, А-01-23
1. Цель темы: изучение способов использования объектов разных типов.
1.1. Преобразование в логический тип с помощью функции bool(<Объект>).
logiz1=bool(56)
print(f"{logiz1}\n")
logiz2=bool(0)
print(f"{logiz2}\n")
logiz3=bool("Beta")
print(f"{logiz3}\n")
logiz4=bool("")
print(f"{logiz4}\n")
Ответ программы:
True
False
True
False
1.2. Преобразование в целое десятичное число объекта с заданной системой счисления.
Преобразование в целое десятичное число объекта с заданной системой счисления осуществляется с помощью функции int(<Объект>[,<Система счисления, в которой определен объект>]). По умолчанию система счисления принимается десятичной.
tt1=int(198.6) #Отбрасывается дробная часть
print(f"{tt1}\n")
tt2=int("-76") #Число – в строке символов, система по умолчанию - десятичная
print(f"{tt2}\n")
tt3=int("B",16)
print(f"{tt3}\n")
tt4=int("71",8)
print(f"{tt4}\n")
tt5=int("98.76")
print(f"{tt5}\n")
Ответ программы:
198
-76
11
57
Traceback (most recent call last):
File "/home/user/Desktop/VUZ/3CURSE/POAS_labs/python-labs/TEMA3/task1.py", line 26, in <module>
tt5=int("98.76")
^^^^^^^^^^^^
ValueError: invalid literal for int() with base 10: '98.76'
Объясните, почему при выполнении последней инструкции выдано диагностическое сообщение.
"98.76" - это строка. Функция int принимает либо строку с целым числом, либо число с точкой, но не строку с числом с точкой. Вариант решения - использовать функцию float(), которая преобразует строку в вещественное число, а затем функцию int() для преобразование в целое:
tt5=int(float("98.76"))
print(f"{tt5}\n")
Ответ программы:
98
Преобразование целых чисел или строк символов в вещественное число – с помощью функции float(<Объект>).
flt1=float(789)
print(f"{flt1}\n")
flt2=float(-6.78e2)
print(f"{flt2}\n")
flt3=float("Infinity")
print(f"{flt3}\n")
flt4=float("-inf")
print(f"{flt4}\n")
Ответ программы:
789.0
-678.0
inf
-inf
1.3. Преобразование десятичных чисел в другие системы счисления.
hh=123
dv1=bin(hh) #Преобразование в строку с двоичным представлением
print(f"{dv1}\n")
vos1=oct(hh) # Преобразование в строку с восьмеричным представлением
print(f"{vos1}\n")
shs1=hex(hh) # Преобразование в строку с шестнадцатеричным представлением
print(f"{shs1}\n")
Ответ программы:
0b1111011
0o173
0x7b
Для проверки выполним обратные преобразования объектов dv1, vos1, shs1 по образцу int(dv1,2):
print(f"{int(dv1, 2)}\n")
print(f"{int(vos1, 8)}\n")
print(f"{int(shs1, 16)}\n")
Ответ программы:
123
123
123
2. Преобразование более сложных базовых типов объектов.
2.1. Преобразование в строку символов с помощью функции str(<Объект>).
strk1=str(23.6)
print(f"{strk1}\n")
strk2=str(logiz3)
print(f"{strk2}\n")
strk3=str(["A","B","C"]) #Преобразуем список
print(f"{strk3}\n")
strk4=str(("A","B","C")) #Преобразуем кортеж
print(f"{strk4}\n")
strk5=str({"A":1,"B":2,"C":9}) #Преобразуем словарь
print(f"{strk5}\n")
Ответ программы:
23.6
True
['A', 'B', 'C']
('A', 'B', 'C')
{'A': 1, 'B': 2, 'C': 9}
2.2. Преобразование элементов объекта в список с помощью функции list(<Объект>).
spis1=list("Строка символов") #Заданная строка разделяется на символы
print(f"{spis1}\n")
spis2=list((124,236,-15,908)) #Кортеж превращается в список
print(f"{spis2}\n")
spis3=list({"A":1,"B":2,"C":9}) #Преобразование словаря в список
print(f"{spis3}\n")
Ответ программы:
['С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в']
[124, 236, -15, 908]
['A', 'B', 'C']
Обратите внимание на то, что из словаря попало в созданный список. Придумайте инструкцию, обеспечивающую создание из того же словаря списка с другими его частями.
list(словарь) берёт только ключи словаря.
.items() — это метод словаря, который даёт представление (view) пар (ключ, значение). Возвращает не список, а объект-«вид» (dict_items). Он живой: если словарь меняется, меняется и этот вид.
spis3=list({"A":1,"B":2,"C":9}.items()) #Преобразование словаря в список
print(f"{spis3}\n")
Ответ программы:
[('A', 1), ('B', 2), ('C', 9)]
2.3. Преобразование элементов объектов в кортеж с помощью функции tuple(<Объект>).
kort7=tuple('Строка символов') #Преобразование строки символов в кортеж8
print(f"{kort7}\n")
kort8=tuple(spis2) #Преобразование списка в кортеж
print(f"{kort8}\n")
kort9=tuple({"A":1,"B":2,"C":9}) #Преобразование словаря в кортеж
print(f"{kort9}\n")
Ответ программы:
('С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в')
(124, 236, -15, 908)
('A', 'B', 'C')
2.4. Удаление объектов.
Очистить оперативную память от ранее созданных объектов можно с помощью инструкции del.
print(f"Объекты в пространстве до удаления:\n{dir()}\n")
del strk5, kort8
print(f"Объекты в пространстве после удаления:\n{dir()}\n")
Ответ программы:
Объекты в пространстве до удаления:
['__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'kort7', 'kort8', 'kort9', 'logiz3', 'spis1', 'spis2', 'spis3', 'strk1', 'strk2', 'strk3', 'strk4', 'strk5']
Объекты в пространстве после удаления:
['__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'kort7', 'kort9', 'logiz3', 'spis1', 'spis2', 'spis3', 'strk1', 'strk2', 'strk3', 'strk4']
Задание.
Создайте строку со своей фамилией и инициалами, преобразуйте её в список, затем список – в кортеж и, наконец, кортеж – в строку.
name="TerekhovFV"
print(f"{name}\n{type(name)}\n")
list_name=list(name)
print(f"{list_name}\n{type(list_name)}\n")
tuple_name=tuple(list_name)
print(f"{tuple_name}\n{type(tuple_name)}\n")
string_name=str(tuple_name)
print(f"{string_name}\n{type(string_name)}\n")
Ответ программы:
TerekhovFV
<class 'str'>
['T', 'e', 'r', 'e', 'k', 'h', 'o', 'v', 'F', 'V']
<class 'list'>
('T', 'e', 'r', 'e', 'k', 'h', 'o', 'v', 'F', 'V')
<class 'tuple'>
('T', 'e', 'r', 'e', 'k', 'h', 'o', 'v', 'F', 'V')
<class 'str'>
3. Арифметические операции.
3.1. Сложение и вычитание (+ и -).
print(12+7+90) # Сложение целых чисел
print(5.689e-1 - 0.456) #Вычитание вещественных чисел
print(23.6+54) #Сложение вещественного и целого чисел
print(14-56.7+89) # Сложение и вычитание целых и вещественных чисел
Ответ программы:
109
0.11289999999999994
77.6
46.3
3.2. Умножение (*).
print(-6.7*12) #Умножение вещественного числа на целое число
Ответ программы:
-80.4
3.3. Деление (/).
print(-234.5/6) #Деление вещественного числа на целое
a=178/45 #Деление двух целых чисел
print(f"a={a}\n{type(a)}\n")
Ответ программы:
-39.083333333333336
a=3.9555555555555557
<class 'float'>
3.4. Деление с округлением вниз (//).
Здесь результат может быть целым или вещественным.
b=178//45 #Деление двух целых чисел
print(f"b={b}\n{type(b)}\n")
c=-24.6//12.1 #Деление двух вещественных чисел
print(f"c={c}\n{type(c)}\n")
Ответ программы:
b=3
<class 'int'>
c=-3.0
<class 'float'>
Самостоятельно попробуйте смешанные комбинации типов чисел в этой операции.
b=b//c
print(f"b={b}\n{type(b)}\n")
c=c//int(b)
print(f"c={c}\n{type(c)}\n")
Ответ программы:
b=-1.0
<class 'float'>
c=3.0
<class 'float'>
Значит если хотя бы одно из чисел вещественное, то ответ будет вещественным.
3.5. Получение остатка от деления (%).
print(148%33) #Остаток от деления двух целых чисел
print(12.6%3.8) #Остаток от деления двух вещественных чисел
Ответ программы:
16
1.2000000000000002
Самостоятельно попробуйте смешанные комбинации типов чисел в этой операции.
print(1%0.3)
print(3.0%1)
Ответ программы:
0.10000000000000003
0.0
Значит если хотя бы одно из чисел вещественное, то ответ будет вещественным.
3.6. Возведение в степень (**).
print(14**3) #Целое число возводится в целую степень
e=2.7**3.6 #Вещественное число возводится в вещественную степень
print(e)
Ответ программы:
2744
35.719843790663525
Самостоятельно попробуйте смешанные комбинации типов чисел в этой операции.
print(4**2.5)
print(4.0**2)
Ответ программы:
32.0
16.0
Значит если хотя бы одно из чисел вещественное, то ответ будет вещественным.
Задание.
Попробуйте операции с участием комплексных чисел. Какие из приведенных выше операций можно применять к комплексным числам, а какие – нет?
- Классические сложение, вычитание, умножение, деление:
print((5-9j)+(2+5j))
print((5-9j)-(2+5j))
print((5-9j)*(2+5j))
print((5-9j)/(2+5j))
Ответ программы:
(7-4j)
(3-14j)
(55+7j)
(-1.206896551724138-1.4827586206896552j)
- Остаток от деления:
print((5-9j)%(2+5j))
Ответ программы:
Traceback (most recent call last):
File "/home/user/Desktop/VUZ/3CURSE/POAS_labs/python-labs/TEMA3/task3.py", line 46, in <module>
print((5-9j)%(2+5j))
~~~~~~^^~~~~~
TypeError: unsupported operand type(s) for %: 'complex' and 'complex'
Нельзя получить остаток от деления компексных чисел.
- Деление с округлением в меньшую сторону:
print((5-9j)//(2+5j))
Ответ программы:
Traceback (most recent call last):
File "/home/user/Desktop/VUZ/3CURSE/POAS_labs/python-labs/TEMA3/task3.py", line 47, in <module>
print((5-9j)//(2+5j))
~~~~~~^^~~~~~~
TypeError: unsupported operand type(s) for //: 'complex' and 'complex'
- Возведение в степень:
print((5-9j)**(2+5j))
Ответ программы:
(-21509.595911266613-2297.8216985074932j)
Можно комплексное число возвести в комплексную степень.
Нетрудно заметить, что в результате операции над числами разных типов получается число, имеющее наиболее сложный тип из тех типов, которые участвуют в операции.
4. Операции с двоичными представлениями целых чисел.
4.1. Двоичная инверсия (~). Значение каждого бита в представлении числа заменяется на противоположное значение (0 на 1, 1 на 0).
dv1=9
dv2=~dv1
print(bin(dv1))
print(bin(dv2))
Ответ программы:
0b1001
-0b1010
4.2. Двоичное «И» (&) – побитовое совпадение двоичных представлений чисел.
print(bin(7&9)) # 111 и 1001 = 0001
print(bin(7&8)) # 111 и 1000 = 0000
Ответ программы:
0b1
0b0
4.3. Двоичное «ИЛИ» (|) – побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда равны 0.
print(bin(7|9)) # 111 или 1001 = 1111
print(bin(7|8)) # 111 или 1000 = 1111
print(bin(14|5)) # 1110 или 0101 = 1111
Ответ программы:
0b1111
0b1111
0b1111
4.4. Двоичное «исключающее ИЛИ»(^) - побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда имеют одинаковые значения – оба 0 или оба 1.
print(bin(14^5)) # 1110 исключающее или 0101 = 1011
print(f"В десятичном представлении: {14^5}")
Ответ программы:
0b1011
В десятичном представлении: 11
4.5. Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева.
h=14 #Двоичное представление = 1110
print(f"В десятичном представлении: {h}")
print(f"В двоичном представлении: {bin(h)}\n")
g=h<<2 # Новое двоичное представление = 111000
print(f"В десятичном представлении: {g}")
print(f"В двоичном представлении: {bin(g)}\n")
g1=h>>1 # Новое двоичное представление = 0111
print(f"В десятичном представлении: {g1}")
print(f"В двоичном представлении: {bin(g1)}\n")
g2=h>>2 # Новое двоичное представление = 0011
print(f"В десятичном представлении: {g2}")
print(f"В двоичном представлении: {bin(g2)}\n")
Ответ программы:
В десятичном представлении: 14
В двоичном представлении: 0b1110
В десятичном представлении: 56
В двоичном представлении: 0b111000
В десятичном представлении: 7
В двоичном представлении: 0b111
В десятичном представлении: 3
В двоичном представлении: 0b11
Задание.
Придумайте два двоичных числа, не менее чем с 7 знаками, и попробуйте выполнить с ними разные операции.
a = 91
b = 101
print(f"В десятичном представлении a: {a}")
print(f"В двоичном представлении a: {bin(a)}\n")
print(f"В десятичном представлении: {b}")
print(f"В двоичном представлении: {bin(b)}\n")
print(f"В десятичном представлении a & b = {a&b}")
print(f"В двоичном представлении a & b = {bin(a&b)}\n")
print(f"В десятичном представлении a | b = {a|b}")
print(f"В двоичном представлении a | b = {bin(a|b)}\n")
print(f"В десятичном представлении a ^ b = {a^b}")
print(f"В двоичном представлении a ^ b = {bin(a^b)}\n")
print(f"В десятичном представлении ~a = {~a}")
print(f"В двоичном представлении ~a = {bin(~a)}\n")
print(f"В десятичном представлении ~a = {~b}")
print(f"В двоичном представлении ~a = {bin(~b)}\n")
print(f"В десятичном представлении a<<4 = {a<<4}")
print(f"В двоичном представлении a<<4 = {bin(a<<4)}\n")
print(f"В десятичном представлении b>>5 = {b>>5}")
print(f"В двоичном представлении b>>5 = {bin(b>>5)}\n")
Ответ программы:
В десятичном представлении a | b = 127
В двоичном представлении a | b = 0b1111111
В десятичном представлении a ^ b = 62
В двоичном представлении a ^ b = 0b111110
В десятичном представлении ~a = -92
В двоичном представлении ~a = -0b1011100
В десятичном представлении ~a = -102
В двоичном представлении ~a = -0b1100110
В десятичном представлении a<<4 = 1456
В двоичном представлении a<<4 = 0b10110110000
В десятичном представлении b>>5 = 3
В двоичном представлении b>>5 = 0b11
5. Операции при работе с последовательностями (строками, списками, кортежами).
5.1. Объединение последовательностей (конкатенация)(+).
print('Система '+'регулирования') #Соединение двух строк символов
print(['abc','de','fg']+['hi','jkl']) # Объединение двух списков
print(('abc','de','fg')+('hi','jkl')) # Объединение двух кортежей
Ответ программы:
Система регулирования
['abc', 'de', 'fg', 'hi', 'jkl']
('abc', 'de', 'fg', 'hi', 'jkl')
5.2. Повторение (*).
print('ля-'*5) #Повторение строки 5 раз
print(['ку','-']*3) #Повторение списка 3 раза
print(('кис','-')*4) #Повторение кортежа 4 раза
Ответ программы:
ля-ля-ля-ля-ля-
['ку', '-', 'ку', '-', 'ку', '-']
('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-')
Создание списка со 100 отсчетами сигнала-ступеньки:
signal1=[0]*3+[1]*99
print(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
print(signal2)
print("\n")
Ответ программы:
(0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0)
5.3. Проверка наличия заданного элемента в последовательности (in).
stroka='Система автоматического управления'
print('автомат' in stroka) #Наличие подстроки в строке
print('ку' in ['ку','-']*3) #Наличие контекста в списке
print('ля-' in ('abc', 'de', 'fg', 'hi', 'jkl')) #Наличие контекста в кортеже
Ответ программы:
True
True
False
5.4. Подстановка значений в строку с помощью оператора «%».
Пример №1
stroka='Температура = %g %s %g'
print(stroka % (16,' меньше ',25))
Ответ программы:
Температура = 16 меньше 25
Пример №2
stroka='Температура = %(zn1)g %(sravn)s %(zn2)g'
print(stroka % {'zn1':16,'sravn':' меньше ','zn2':25})
Ответ программы:
Температура = 16 меньше 25
6. Оператор присваивания.
6.1. Обычное присваивание значения переменной (=).
zz=-12
print(zz)
Ответ программы:
-12
6.2. Увеличение значения переменной на заданную величину (+=) или уменьшение (-=).
zz+=5 # Значение zz увеличивается на 5
print(zz)
zz-=3 # Значение уменьшается на 3
print(zz)
Ответ программы:
-7
-10
Для последовательностей операция (+=) означает конкатенацию текущего значения объекта с заданным дополнением.
stroka='Система'
stroka+=' регулирования'
print(stroka)
Ответ программы:
Система регулирования
6.3. Умножение текущего значения переменной на заданную величину (*=) или деление (/=).
zz/=2
print(zz)
zz*=5
print(zz)
Ответ программы:
-5.0
-25.0
Для строк операция (*=) означает повторение текущего значения объекта заданное число раз.
stroka*= 3
print(stroka)
Ответ программы:
Система регулированияСистема регулированияСистема регулирования
6.4. Деления с округлением вниз (//=).
zz//=2
print(zz)
Ответ программы:
-13.0
6.5. Возведение в степень.
zz**=2
print(zz)
Ответ программы:
169.0
6.6. Получение остатка от деления (%=).
zz%=3
print(zz)
Ответ программы:
1.0
Множественное присваивание.
w=v=10 # Переменным присваивается одно и то же значение
print(w)
print(v)
n1,n2,n3=(11,-3,'all') #Значения переменных берутся из кортежа
print(n1, n2, n3)
Ответ программы:
10
10
11 -3 all
Вместо кортежа нельзя использовать строку
n1,n2,n3="11,-3,'all'"
print(n1, n2, n3)
Ответ программы:
Traceback (most recent call last):
File "/home/user/Desktop/VUZ/3CURSE/POAS_labs/python-labs/TEMA3/task6.py", line 40, in <module>
n1,n2,n3="11,-3,'all'"
^^^^^^^^
ValueError: too many values to unpack (expected 3)
Вместо кортежа можно использовать список
n1,n2,n3=[11,-3,'all']
print(n1, n2, n3)
Ответ программы:
11 -3 all
Вместо кортежа можно использовать множество
n1,n2,n3={11,-3,'all'}
print(n1, n2, n3)
Ответ программы:
11 -3 all
Вместо кортежа можно использовать словарь
n1,n2,n3={'11':1,'-3':2,"all": 3}
print(n1, n2, n3)
Ответ программы:
11 -3 all
7. Логические операции – при создании логических выражений, дающих в результате вычисления значения True или False.
7.1. Операции сравнение: равенство (==), не равно (!=), меньше (<), больше (>), меньше или равно (<=), больше или равно (>=).
w=v=10
print(w>=v)
print(w==v)
print(w<=v)
print(w!=v)
print(w<v)
print(w>v)
Ответ программы:
True
True
True
False
False
False
7.2. Проверка наличия заданного элемента в последовательности или во множестве, а также проверка наличия ключа в словаре (in).
- Операции с множеством
mnoz1={'pen','book','pen','iPhone','table','book'}
print('book' in mnoz1)
print('cap' in mnoz1)
Ответ программы:
True
False
- Операции со словарём
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
print('Vologda' in dic1)
print('Pskov' in dic1)
print(56 in dic1.values())
Ответ программы:
True
False
True
Ещё один пример работы со словарём
dct1={'Institut':['AVTI','IEE','IBB'],'Depart':['UII','PM','VMSS','MM'],'gruppa': ['A-01-15','A-02-15']}
print('UII' in dct1['Depart'])
print(dct1['Depart'][1] == 'MM')
Ответ программы:
True
False
7.3. Создание больших логических выражений с использованием соединительных слов: логическое «И» (and), логическое «ИЛИ» (or), логическое «НЕ» (not).
a=17
b=-6
print((a>=b) and ('book' in mnoz1) and ('Pskov' not in dic1))
print((a % 2 == 1) and (b < 0) and (('Moscow' in dic1) or ('Pskov' not in dic1)))
print(not (a <= b) and (('pen' in mnoz1) or ('book' not in mnoz1)) and ('Kazan' not in dic1))
print((len(mnoz1) >= 3) and (a + b > 0) or (('Pskov' in dic1) and (dic1['Pskov'] > 50)))
Ответ программы:
True
True
True
True
7.4. Проверка ссылок переменных на один и тот же объект (is).
w=v=10 #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти
print(w is v)
w1=['A','B']
v1=['A','B']
print(w1 is v1)
Ответ программы:
True
False
is сравнивает тождество объектов, а не равенство значений. При w = v = 10 обе переменные указывают на один и тот же объект, а w1 = ['A','B'] и v1 = ['A','B'] создают две разные списочные коробки с одинаковым содержимым.
Чтобы тождество объектов было верным необходимо, чтобы АДРЕС объектов был тот же. Адрес можно проверить с помощью функции id(). == спрашивает "содержимое одинаковое?", а is спрашивает "это один и тот же объект?".
8. Операции с объектами, выполняемые с помощью методов.
Полный список всех атрибутов любого объекта можно получить с использованием функции dir.
stroka='Микропроцессорная система управления'
print(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']
8.1. Методы для работы со строками.
- Методы find, count, replace, split, upper, join, partition, rpartition.
stroka='Микропроцессорная система управления'
print(stroka.find('пр')) #Возвращает номер позиции первого вхождения указанного контекста или значение -1
print(stroka.count("с")) #Подсчет числа вхождений строки “с” в stroka
stroka.replace(' у',' автоматического у')
print(stroka)
spis22=stroka.split(' ') #Возвращает список подстрок, между которыми в строке стоит заданный разделитель
print(spis22)
print(stroka.upper()) #Возвращает строку со всеми заглавными буквами
stroka3=" ".join(spis22) #Возвращает строку, собранную из элементов списка
print(stroka3)
print(stroka3.partition("с")) #Возвращает кортеж с результатами поиска «с» слева
print(stroka3.rpartition("с")) #Возвращает кортеж с результатами поиска «с» справа
Ответ программы:
5
4
Микропроцессорная система управления
['Микропроцессорная', 'система', 'управления']
МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ
Микропроцессорная система управления
('Микропроце', 'с', 'сорная система управления')
('Микропроцессорная си', 'с', 'тема управления')
- Метод format.
strk1 = 'Момент времени {}, значение = {}'
print(strk1.format(1, 89.7))
strk2='Момент времени {1}, значение = {0}:{2}'
print(strk2.format(36.7,2,'норма!'))
strk3='Момент времени {num}, значение = {znch}'
print(strk3.format(znch=89.7,num=2))
Ответ программы:
нт времени 1, значение = 89.7
Момент времени 2, значение = 36.7:норма!
Момент времени 2, значение = 89.7
8.2. Методы для работы со списками.
- Метод pop(индекс) удаляет элемент по индексу.
- Метод append(элемент) добавляет элемент в конец списка.
- Метод insert(индекс, элемент) вставляет элемент в заданный индекс. Последующие индекс сдвигаются вправо.
- Метод count(элемент) подсчитывает количество заданных элементов в списке.
spsk=['a','b','c','d','e','f']
print(spsk)
spsk.pop(2)
print(spsk)
spsk.append('c')
print(spsk)
spsk.insert(2,'a')
print(spsk)
print(spsk.count('a'))
Ответ программы:
['a', 'b', 'c', 'd', 'e', 'f']
['a', 'b', 'd', 'e', 'f']
['a', 'b', 'd', 'e', 'f', 'c']
['a', 'b', 'a', 'd', 'e', 'f', 'c']
2
8.3. Методы для работы с кортежами.
У кортежа всего два собственных метода: count(элемент) и index(элемент).
t = (10, 20, 20, 30, 40)
print(t.count(20)) # сколько раз встречается 20
print(t.index(30)) # индекс первого вхождения 30
Ответ программы:
2
3
8.4. Методы для работы со словарями.
- keys() - отображает ключи
- values() - отображает значения
- items() - отображает пары ключей и значений
- get(k, default=None) - безопасное чтение - вернуть d[k], а если ключа нет — default, без ошибки.
- d[k] = v - присвоение значения по ключу (добавит или перезапишет)
- d.setdefault(k, default=None) – вернуть d[k], а если ключа нет — создать его со значением default и вернуть.
- d.pop(k[, default]) - удалить ключ и вернуть значение; если нет и default не задан — ошибка.
- d.popitem() - удалить последнюю добавленную пару (LIFO) и вернуть её кортежем.
- d.clear() – очистить словарь.
d = {'A': 1, 'B': 2, 'C': 3}
print("start:", d)
print(d.keys())
print(d.values())
print(d.items(),'\n')
print(d.get('B', 0))
print(d.get('Z', 0),'\n')
d['D'] = 4
d['A'] = 10
print(d,'\n')
print(d.setdefault('E', 5))
print(d.setdefault('A', 999),'\n')
print(d,'\n')
val = d.pop('B')
print(val, d)
print(d.pop('Z', 'нет'),'\n')
last_key, last_val = d.popitem()
print((last_key, last_val))
print(d,'\n')
d.clear()
print(d)
Ответ программы:
start: {'A': 1, 'B': 2, 'C': 3}
dict_keys(['A', 'B', 'C'])
dict_values([1, 2, 3])
dict_items([('A', 1), ('B', 2), ('C', 3)])
2
0
{'A': 10, 'B': 2, 'C': 3, 'D': 4}
5
10
{'A': 10, 'B': 2, 'C': 3, 'D': 4, 'E': 5}
2 {'A': 10, 'C': 3, 'D': 4, 'E': 5}
нет
('E', 5)
{'A': 10, 'C': 3, 'D': 4}
{}
8.5. Методы для работы с множествами.
- s = set([1, 2, 2, 3]) - создаёт множество без повторяющихся элементов.
- empty = set() - пустое множество.
- s.add(4) - добавляет элемент в множество.
- s.update([5,6]) - добавляет несколько элементов.
- s.remove(2) - удаляет элемент множества, если нет - KeyError.
- s.discard(99) - удаляет элемент, если нет — тихо.
- x = s.pop() - удаляет элемент множества.
- s.clear() - очищает множество.
- a.issubset(b) - множество a принадлежит множеству b.
- a.issuperset(b) - множество b ринадлежит множеству a.
- t = a.copy() - копирует множество.
- fs = frozenset({1,2,3}) - неизменяемое множество.
s = set([1, 2, 2, 3])
print("s:", s)
empty = set()
print("empty:", empty)
s.add(4)
print("add(4):", s)
s.update([5, 6])
print("update([5,6]):", s)
s.remove(2)
print("remove(2):", s)
s.discard(99)
print("discard(99):", s)
x = s.pop()
print("pop() ->", x, "; s:", s)
s.clear()
print("clear():", s)
a = {1, 2}
b = {1, 2, 3}
print("a:", a, "b:", b)
print("a.issubset(b):", a.issubset(b))
print("a.issuperset(b):", a.issuperset(b))
print("b.issuperset(a):", b.issuperset(a))
a2 = a.copy()
print("copy() a2:", a2)
fs = frozenset({1, 2, 3})
print("frozenset fs:", fs, type(fs))
Ответ программы:
s: {1, 2, 3}
empty: set()
add(4): {1, 2, 3, 4}
update([5,6]): {1, 2, 3, 4, 5, 6}
remove(2): {1, 3, 4, 5, 6}
discard(99): {1, 3, 4, 5, 6}
pop() -> 1 ; s: {3, 4, 5, 6}
clear(): set()
a: {1, 2} b: {1, 2, 3}
a.issubset(b): True
a.issuperset(b): False
b.issuperset(a): True
copy() a2: {1, 2}
frozenset fs: frozenset({1, 2, 3}) <class 'frozenset'>