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

20 KiB

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

Похил Анастасия, А-02-23

1. Настройка текущего каталога.

import os
os.chdir('C://Users//Настя//Desktop//python-labs//TEMA3//')

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

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

logiz1 = bool(56)
logiz2 = bool(0)
logiz3 = bool("Beta")
logiz4 = bool("")
logiz1
True
logiz2
False
logiz3
True
logiz4
False
type(logiz1)
<class 'bool'>

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#19>", line 1, in <module>
    tt5=int("98.76")
ValueError: invalid literal for int() with base 10: '98.76'
  • Преобразование целых чисел или строк символов в вещественное число
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
dv1 = bin(hh)  #Преобразование в строку с двоичным представлением
vos1 = oct(hh)  # Преобразование в строку с восьмеричным представлением
shs1 = hex(hh)   # Преобразование в строку с шестнадцатеричным представлением
dv1
'0b1111011'
vos1
'0o173'
shs1
'0x7b'
int(dv1,2)
123
int(vos1, 8)
123
int(shs1, 16)
123

3. Преобразования более сложных базовых типов объектов.

3.1. Преобразование в строку символов

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']
  • Методы .values(), .items()
spis3 = list({"A":1,"B":2,"C":9}.values())
spis3
[1, 2, 9]
spis3 = list({"A":1,"B":2,"C":9}.items())
spis3
[('A', 1), ('B', 2), ('C', 9)]

3.3. Преобразование элементов объектов в кортеж

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 strk5, kort8
strk5
Traceback (most recent call last):
  File "<pyshell#62>", line 1, in <module>
    strk5
NameError: name 'strk5' is not defined. Did you mean: 'strk1'?
kort8
Traceback (most recent call last):
  File "<pyshell#63>", line 1, in <module>
    kort8
NameError: name 'kort8' is not defined. Did you mean: 'kort7'?
str_A = "Похил А.А"
spis_A = list(str_A)
spis_A
['П', 'о', 'х', 'и', 'л', ' ', 'А', '.', 'А']
kort_A = tuple(spis_A)
kort_A
('П', 'о', 'х', 'и', 'л', ' ', 'А', '.', 'А')
str_AA = str(kort_A)
str_AA
"('П', 'о', 'х', 'и', 'л', ' ', 'А', '.', 'А')"

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
type(b)
<class 'int'>
c = -24.6//12.1  #Деление двух вещественных чисел
c
-3.0
type(c)
<class 'float'>
d = 23.65//12
d
1.0
type(d)
<class 'float'>
d = 12//52.43
d
0.0
type(d)
<class 'float'>
d = 6//2
d
3
type(d)
<class 'int'>

4.5. Получение остатка от деление

148%33  #Остаток от деления двух целых чисел
16
12.6%3.8  #Остаток от деления двух вещественных чисел
1.2000000000000002
256%2.5
1.0
34.2%4
2.200000000000003

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

14**3  #Целое число возводится в целую степень
2744
e = 2.7**3.6  #Вещественное число возводится в вещественную степень
e
35.719843790663525
52**1.2
114.60511792303392
0.3**11
1.7714699999999993e-06

4.7. Операции с комплексными числами

z1 = 3 + 2j
z2 = 6 - 4j
z1 + z2
(9-2j)
z1 * z2
(26+0j)
z1 / z2
(0.19230769230769232+0.46153846153846156j)
z1 // z2
Traceback (most recent call last):
  File "<pyshell#59>", line 1, in <module>
    z1 // z2
TypeError: unsupported operand type(s) for //: 'complex' and 'complex'
z1 % z2
Traceback (most recent call last):
  File "<pyshell#60>", line 1, in <module>
    z1 % z2
TypeError: unsupported operand type(s) for %: 'complex' and 'complex'
z1**z2
(-717.4651414273118-23072.00404010235j)

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

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

dv1 = 9
dv2 = ~dv1
dv2
-10

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

7 & 9  # 111 и 1001 = 0001
1
7 & 8  # 111 и 1000 = 0000
0

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

7 | 9     # 111 или 1001 = 1111
15
7 | 8     # 111 или 1000 = 1111
15
14 | 5   # 1110 или 0101 = 1111
15

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

14 ^ 5  # 1110 исключающее или 0101 = 1011
11

Число 11 получилось при переводе 1011 из двоичной системы в десятичную.

5.5. Сдвиг двоичного представления на заданное число разрядов влево или вправо с дополнением нулями

h = 14   #Двоичное представление = 1110
g = h<<2  # Новое двоичное представление = 111000
g
56
g1 = h>>1  # Новое двоичное представление = 0111
g1
7
g2 = h>>2  # Новое двоичное представление = 0011
g2
3
h0 = 127
bin(h0)
'0b1111111'
g0 = h0<<1
g0
254
bin(g0)
'0b11111110'
g0 = h0>>3
g0
15
bin(g0)
'0b1111'

Создание двух двоичных чисел с 7-ю знаками и выполнение операций над ними:

b1 = int("1010101",2)
b2 = int("1111001",2)
b_2 = ~b2
b_2
-122
b1 & b2
81
b1 | b2
125
b1^b2
44
b1 >> 1
42
b2 << 3
968
b1
85
b2
121

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 раза
('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-')
signal1 = [0]*3 + [1]*99
signal2 = (0,)*3 + (1,)*5 + (0,)*7
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, 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 = 'Температура = %(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 -= 3  # Значение уменьшается на 3
zz
-10
stroka='Система'
stroka+=' регулирования'
stroka
'Система регулирования'

7.3. Умножение текущего значения переменной на заданную величину (*=) или деление (/=)

zz /= 2
zz
-5.0
zz *= 5
zz
-25.0
stroka='Система регулирования'
stroka *= 2
stroka
'Система регулированияСистема регулирования'

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

zz //= 3
zz
-9.0
zz %= 2
zz
1.0
zz **= 3
zz
1.0
7.5. Множественное присваивание
w = v = 10  # Переменным присваивается одно и то же значение
w
10
v
10
n1,n2,n3 = (11,-3,'all')  #Значения переменных берутся из кортежа
n1;n2;n3
11
-3
'all'
n1,n2,n3 = "11", "-3", "all"
n1;n2;n3
'11'
'-3'
'all'
n1,n2,n3 = [11,-3,'all']
n1;n2;n3
11
-3
'all'
n1,n2,n3 = {11: 1,-3:2,'all':3}
n1;n2;n3
11
-3
'all'

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

8.1. Операции сравнения

w = v = 10
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. Логическое «И» (and), логическое «ИЛИ» (or), логическое «НЕ» (not)

a = 17
b = -6
(a >= b) and ('book' in mnoz1) and not ('Pskov' in dic1)
True
(5 > 6) and ('kazan' in dic1) and not ('lozhka' in mnoz1)
False
(5 > 6) and (7 > 5) or ("Saratov" in dic1)
True

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

w = v = 10  #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти
w is v
True
w1 = ['A','B']
v1 = ['A','B']
w1 is v1 #При раздельном создании списков с одинаковыми элементами получаются разные объекты в памяти, поэтому is возвращает False.Оператор is проверяет идентичность объектов (ссылку на один объект), а не равенство содержимого 
False

9. Операции с объектами, выполняемые с помощью методов.

stroka = 'Микропроцессорная система управления'
dir(stroka)
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']

9.1. Методы для работы со строками

stroka.find('пр')  #Возвращает номер позиции первого вхождения указанного контекста или значение -1
5
stroka.count("с")  #Подсчет числа вхождений строки “с” в stroka
4
stroka.replace(' у',' автоматического у')
'Микропроцессорная система автоматического управления'
spis22 = stroka.split(' ')  #Возвращает список подстрок, между которыми в строке стоит заданный разделитель
spis22
['Микропроцессорная', 'система', 'управления']
stroka.upper()  #Возвращает строку со всеми заглавными буквами
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
stroka3 = " ".join(spis22)  #Возвращает строку, собранную из элементов списка
stroka3
'Микропроцессорная система управления'
stroka3.partition("с")  #Возвращает кортеж с результатами поиска «с» слева
('Микропроце', 'с', 'сорная система управления')
stroka3.rpartition("с")  #Возвращает кортеж с результатами поиска «с» справа
('Микропроцессорная си', 'с', 'тема управления')
strk1 = 'Момент времени {}, значение = {}'
strk1.format(1,89.7)
'Момент времени 1, значение = 89.7'
strk2 = 'Момент времени {1}, значение = {0}:{2}'
strk2.format(36.7,2,'норма!')
'Момент времени 2, значение = 36.7:норма!'
strk3 = 'Момент времени {num}, значение = {znch}'
strk3.format(znch = 89.7,num = 2)
'Момент времени 2, значение = 89.7'

9.2. Методы для работы со списками

spsk = [1, 'a', 2, 'd', 4]
dir(spsk)
['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
spsk.pop(2)
2
spsk
[1, 'a', 'd', 4]
spsk.append('c')
spsk
[1, 'a', 'd', 4, 'c']
spsk.insert(2, 'a')
spsk
[1, 'a', 'a', 'd', 4, 'c']
spsk.count('a')
2

9.3. Методы для работы с кортежами

t = (1, 2, 3, 2, 4)
dir(t)
['__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']
t.count(2)
2
t.index(3)
2
len(t)
5
t[1]
2

9.4. Методы для работы со словарями и множествами

#словарь
d = {'a': 1, 'b': 2, 'c': 3}
dir(d)
['__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']
d.keys()
dict_keys(['a', 'b', 'c'])
d.values()
dict_values([1, 2, 3])
d.get('b')
2
d.update({'d': 4})
d
{'a': 1, 'b': 2, 'c': 3, 'd': 4}
#множество
s = {1, 2, 3, 2, 4}
dir(s)
['__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']
s.add(5)
s
{1, 2, 3, 4, 5}
s.remove(2)
s
{1, 3, 4, 5}
s.intersection({1, 3}) #пересечение множеств
{1, 3}

10. Закончен сеанс работы с IDLE.