Сравнить коммиты
31 Коммитов
| Автор | SHA1 | Дата | |
|---|---|---|---|
| 6f66915f81 | |||
| 8e76de4897 | |||
| 794737e5dc | |||
| 4376379cfa | |||
| b5f6053beb | |||
| 4d9c903624 | |||
| 84755ea1b2 | |||
| d5a6b8ebd1 | |||
| 5a065ade41 | |||
| 046a19f44a | |||
| b160c212b3 | |||
| 8bcb8692ad | |||
| 8af32b77dd | |||
| edebdeacf4 | |||
| 1ea7dbb683 | |||
| 85ebd5306c | |||
| 2e052faf94 | |||
| 022cacca1f | |||
| c688775929 | |||
| 65c7d40146 | |||
| 8d662c9e35 | |||
| 74a26eb50f | |||
| ace6e9a02d | |||
| c810b11f2c | |||
| 0b4f7d7041 | |||
| 137d88ddc4 | |||
| bacf11bf08 | |||
| aca81e7fd3 | |||
| ab65c96b53 | |||
| 5b09eb86f4 | |||
| 733313c0f5 |
5
TEMA1/Pr0.py
Обычный файл
@@ -0,0 +1,5 @@
|
|||||||
|
#Программа по Теме 1 Мамакин Ярослав Романович
|
||||||
|
print('Hello')
|
||||||
|
h=input('Your name=')
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA1')
|
||||||
Двоичные данные
TEMA1/figure1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 33 KiB |
Двоичные данные
TEMA1/figure2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 217 KiB |
Двоичные данные
TEMA1/figure3.png
Обычный файл
|
После Ширина: | Высота: | Размер: 68 KiB |
Двоичные данные
TEMA1/figure4.png
Обычный файл
|
После Ширина: | Высота: | Размер: 14 KiB |
Двоичные данные
TEMA1/figure5.png
Обычный файл
|
После Ширина: | Высота: | Размер: 414 KiB |
Двоичные данные
TEMA1/figure6.png
Обычный файл
|
После Ширина: | Высота: | Размер: 349 KiB |
Двоичные данные
TEMA1/figure7.png
Обычный файл
|
После Ширина: | Высота: | Размер: 59 KiB |
Двоичные данные
TEMA1/figure8.png
Обычный файл
|
После Ширина: | Высота: | Размер: 141 KiB |
Двоичные данные
TEMA1/figure9.png
Обычный файл
|
После Ширина: | Высота: | Размер: 214 KiB |
49
TEMA1/protocol.py
Обычный файл
@@ -0,0 +1,49 @@
|
|||||||
|
#Протокол по Теме 1 Мамакин Ярослав Романович
|
||||||
|
Python 3.13.7 (tags/v3.13.7:bcee1c3, Aug 14 2025, 14:15:11) [MSC v.1944 64 bit (AMD64)] on win32
|
||||||
|
Enter "help" below or click "Help" above for more information.
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA1')
|
||||||
|
import Pr0
|
||||||
|
Hello
|
||||||
|
Your name=Yaroslav
|
||||||
|
|
||||||
|
import prb1
|
||||||
|
Как Вас зовут? Yaroslav
|
||||||
|
Привет, Yaroslav
|
||||||
|
help(print)
|
||||||
|
Help on built-in function print in module builtins:
|
||||||
|
|
||||||
|
print(*args, sep=' ', end='\n', file=None, flush=False)
|
||||||
|
Prints the values to a stream, or to sys.stdout by default.
|
||||||
|
|
||||||
|
sep
|
||||||
|
string inserted between values, default a space.
|
||||||
|
end
|
||||||
|
string appended after the last value, default a newline.
|
||||||
|
file
|
||||||
|
a file-like object (stream); defaults to the current sys.stdout.
|
||||||
|
flush
|
||||||
|
whether to forcibly flush the stream.
|
||||||
|
|
||||||
|
help(print),help(input)
|
||||||
|
Help on built-in function print in module builtins:
|
||||||
|
|
||||||
|
print(*args, sep=' ', end='\n', file=None, flush=False)
|
||||||
|
Prints the values to a stream, or to sys.stdout by default.
|
||||||
|
|
||||||
|
sep
|
||||||
|
string inserted between values, default a space.
|
||||||
|
end
|
||||||
|
string appended after the last value, default a newline.
|
||||||
|
file
|
||||||
|
a file-like object (stream); defaults to the current sys.stdout.
|
||||||
|
flush
|
||||||
|
whether to forcibly flush the stream.
|
||||||
|
|
||||||
|
Help on built-in function input in module builtins:
|
||||||
|
|
||||||
|
input(prompt='', /)
|
||||||
|
Read a string from standard input. The trailing newline is stripped.
|
||||||
|
|
||||||
|
The prompt string, if given, is printed to standard output without a
|
||||||
|
trailing newline before reading input.
|
||||||
67
TEMA1/report.md
Обычный файл
@@ -0,0 +1,67 @@
|
|||||||
|
# Отчет по теме 1
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Изучение среды IDLE
|
||||||
|
|
||||||
|
## 1.1 Работа с интерпретатором
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.2 Задание рабочей папки в среде IDLE
|
||||||
|
|
||||||
|
```py
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA1')
|
||||||
|
```
|
||||||
|
|
||||||
|
## 1.3 Настройка среды
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.4 Составил программу
|
||||||
|
|
||||||
|
```py
|
||||||
|
#Программа по Теме 1 Мамакин Ярослав Романович
|
||||||
|
print('Hello')
|
||||||
|
h=input('Your name=')
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA1')
|
||||||
|
```
|
||||||
|
|
||||||
|
## 1.5 Запустил программу на выполнение
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.6 Запустил программу prb1.py
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.7 Изучение состава рабочего каталога
|
||||||
|
|
||||||
|
При открытии файла с результатом работы компилятора текстовый редактор выводит бессмысленный набор символов, т. к. результат работы компилятора - двоичный файл
|
||||||
|
|
||||||
|
## 1.8 Изучил команды для быстрой помощи
|
||||||
|
|
||||||
|
```py
|
||||||
|
help(print),help(input)
|
||||||
|
```
|
||||||
|
|
||||||
|
При нажатии F1 открылась страница с документацией:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.9 Работа с окнами редактора
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.10 Изучил программу tdemo_chaos.py
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 1.11 Изучил примеры программ из среды
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
16
TEMA1/test.md
Обычный файл
@@ -0,0 +1,16 @@
|
|||||||
|
# Общее контрольное задание по теме 1
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Вопрос
|
||||||
|
|
||||||
|
Можно ли писать несколько инструкций в одной строке командного окна?
|
||||||
|
|
||||||
|
## Ответ
|
||||||
|
|
||||||
|
Да, можно, инструкции записываются через запятую. Например:
|
||||||
|
|
||||||
|
```py
|
||||||
|
help(print),help(input)
|
||||||
|
```
|
||||||
|
|
||||||
Двоичные данные
TEMA2/figure1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 78 KiB |
Двоичные данные
TEMA2/figure2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 17 KiB |
Двоичные данные
TEMA2/figure3.png
Обычный файл
|
После Ширина: | Высота: | Размер: 28 KiB |
Двоичные данные
TEMA2/figure4.png
Обычный файл
|
После Ширина: | Высота: | Размер: 117 KiB |
Двоичные данные
TEMA2/figure5.png
Обычный файл
|
После Ширина: | Высота: | Размер: 6.2 KiB |
122
TEMA2/protocol.py
Обычный файл
@@ -0,0 +1,122 @@
|
|||||||
|
Протокол по теме 2 Мамакин Ярослав Романович
|
||||||
|
f1=16
|
||||||
|
f2=3
|
||||||
|
dir()
|
||||||
|
dir(f1)
|
||||||
|
type(f2)
|
||||||
|
del f1,f2
|
||||||
|
gg1=1.6
|
||||||
|
hh1='Строка'
|
||||||
|
kluch = keyword.kwlist
|
||||||
|
print(max([len('stroka'), abs(min([-4, -5]))]))
|
||||||
|
Gg1=45
|
||||||
|
gg1,Gg1
|
||||||
|
(1.6, 45)
|
||||||
|
bb1=True
|
||||||
|
type(bb1)
|
||||||
|
ii1=-1234567890
|
||||||
|
type(ii1)
|
||||||
|
dv1=0b1101010
|
||||||
|
type(dv1)
|
||||||
|
cc2=complex(3.67,-0.45)
|
||||||
|
type(cc2)
|
||||||
|
ss1a='Это - \'строка символов \', \n \t выводимая на двух строках'
|
||||||
|
print(ss1a)
|
||||||
|
Это - 'строка символов ',
|
||||||
|
выводимая на двух строках
|
||||||
|
ss1b = 'Меня зовут: \n Мамакин Я. Р.'
|
||||||
|
print(ss1b)
|
||||||
|
Меня зовут:
|
||||||
|
Мамакин Я. Р.
|
||||||
|
ss1='Это - строка символов'
|
||||||
|
print(ss1[17:3:-2])
|
||||||
|
омсаот
|
||||||
|
print(ss1[-4:3:-2])
|
||||||
|
омсаот
|
||||||
|
ss1[4]='='
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#41>", line 1, in <module>
|
||||||
|
ss1[4]='='
|
||||||
|
TypeError: 'str' object does not support item assignment
|
||||||
|
ss1=ss1[:4]+'='+ss1[5:]
|
||||||
|
print(ss1)
|
||||||
|
Это = строка символов
|
||||||
|
print(ss1b[22:24]+ss1b[14:21]+ss1b[-1])
|
||||||
|
Я.Мамакин.
|
||||||
|
spis1=[111,'Spisok',5-9j]
|
||||||
|
stup=[0,0,1,1,1,1,1,1,1]
|
||||||
|
spis1[1]='Список'
|
||||||
|
spis1
|
||||||
|
[111, 'Список', (5-9j)]
|
||||||
|
len(spis1)
|
||||||
|
3
|
||||||
|
spis1.append('New item')
|
||||||
|
spis1.append(ss1b)
|
||||||
|
spis1
|
||||||
|
[111, 'Список', (5-9j), 'New item', 'Меня зовут: \n Мамакин Я. Р.']
|
||||||
|
spis1.pop(1)
|
||||||
|
'Список'
|
||||||
|
stup.remove(1)
|
||||||
|
stup.reverse()
|
||||||
|
stup
|
||||||
|
[1, 1, 1, 1, 1, 1, 0, 0]
|
||||||
|
spis2=[spis1,[4,5,6,7]]
|
||||||
|
spis2[0][1]=78
|
||||||
|
spis1
|
||||||
|
[111, 78, 'New item', 'Меня зовут: \n Мамакин Я. Р.']
|
||||||
|
spis3=[56, 'sem-vosem', False, [7, 8]]
|
||||||
|
stup[-8::2]
|
||||||
|
[1, 1, 1, 0]
|
||||||
|
kort1=(222,'Kortezh',77+8j)
|
||||||
|
kort1= kort1+(1,2)
|
||||||
|
kort2=kort1[:2]+kort1[3:]
|
||||||
|
kort1.index(2)
|
||||||
|
4
|
||||||
|
kort1.count(222)
|
||||||
|
1
|
||||||
|
kort1[2]=90
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#67>", line 1, in <module>
|
||||||
|
kort1[2]=90
|
||||||
|
TypeError: 'tuple' object does not support item assignment
|
||||||
|
kort3=('7-8', 'pyat-shest', (7, 8))
|
||||||
|
kort3
|
||||||
|
('7-8', 'pyat-shest', (7, 8))
|
||||||
|
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
|
||||||
|
dic1['Orel']
|
||||||
|
56
|
||||||
|
dic1['Pskov']=78
|
||||||
|
dic1
|
||||||
|
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78}
|
||||||
|
sorted(dic1.keys())
|
||||||
|
['Orel', 'Pskov', 'Saratov', 'Vologda']
|
||||||
|
sorted(dic1.values())
|
||||||
|
[45, 56, 78, 145]
|
||||||
|
dic2={1:'mean',2:'standart deviation',3:'correlation'}
|
||||||
|
dic3={'statistics':dic2,'POAS':['base','elementary','programming']}
|
||||||
|
dic3['statistics'][2]
|
||||||
|
'standart deviation'
|
||||||
|
dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)])
|
||||||
|
dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]))
|
||||||
|
kortn=(7,8,9,10,11,12,13)
|
||||||
|
listn=['sem', 'vosem', 'devyat', 'desyat', 'odinnadsat']
|
||||||
|
dic6=dict(zip(kortn,listn))
|
||||||
|
dic6
|
||||||
|
{7: 'sem', 8: 'vosem', 9: 'devyat', 10: 'desyat', 11: 'odinnadsat'}
|
||||||
|
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
|
||||||
|
len(mnoz1)
|
||||||
|
4
|
||||||
|
'датчик' in mnoz1
|
||||||
|
True
|
||||||
|
mnoz1.add('реле')
|
||||||
|
mnoz1.remove('линия связи')
|
||||||
|
mno={7, '8', [5, 6]}
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#90>", line 1, in <module>
|
||||||
|
mno={7, '8', [5, 6]}
|
||||||
|
TypeError: unhashable type: 'list'
|
||||||
|
mno={7, '8'}
|
||||||
|
mno.add(7)
|
||||||
|
mno
|
||||||
|
{'8', 7}
|
||||||
|
|
||||||
193
TEMA2/report.md
Обычный файл
@@ -0,0 +1,193 @@
|
|||||||
|
# Отчет по теме 2
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Изучение простых объектов
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
После присваивания значений переменные отображаются в пространстве имен.
|
||||||
|
Тип - int
|
||||||
|
После удаления из оперативной памяти переменные не отображаются в пространстве имен.
|
||||||
|
|
||||||
|
## 2 Правила именования объектов
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Переменные с правильными именами получили свои значения, с неправильными - вызвали диагностическое сообщение.
|
||||||
|
|
||||||
|
## 3 Вывод списка ключевых слов
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Сохранил список в переменную kluch:
|
||||||
|
|
||||||
|
```py
|
||||||
|
kluch = keyword.kwlist
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Cписок встроенных идентификаторов
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Изучил приведенные функции, пример:
|
||||||
|
|
||||||
|
```py
|
||||||
|
print(max([len('stroka'), abs(min([-4, -5]))]))
|
||||||
|
```
|
||||||
|
|
||||||
|
Инструкция выводит длину строки, 6.
|
||||||
|
|
||||||
|
## 5 Чувствительность к регистру
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 6 Базовые типы объектов
|
||||||
|
|
||||||
|
Логический
|
||||||
|
```py
|
||||||
|
>>>bb1=True
|
||||||
|
>>>type(bb1)
|
||||||
|
<class 'bool'>
|
||||||
|
```
|
||||||
|
Числовые
|
||||||
|
```py
|
||||||
|
>>>ii1=-1234567890
|
||||||
|
>>>type(ii1)
|
||||||
|
<class 'int'>
|
||||||
|
>>>dv1=0b1101010
|
||||||
|
>>>type(dv1)
|
||||||
|
<class 'int'>
|
||||||
|
>>>cc2=complex(3.67,-0.45)
|
||||||
|
>>>type(cc2)
|
||||||
|
<class 'complex'>
|
||||||
|
```
|
||||||
|
Строка
|
||||||
|
```py
|
||||||
|
>>>ss1a='Это - \'строка символов \', \n \t выводимая на двух строках'
|
||||||
|
>>>print(ss1a)
|
||||||
|
Это - 'строка символов ',
|
||||||
|
выводимая на двух строках
|
||||||
|
>>>ss1b = 'Меня зовут: \n Мамакин Я. Р.'
|
||||||
|
>>>print(ss1b)
|
||||||
|
Меня зовут:
|
||||||
|
Мамакин Я. Р.
|
||||||
|
>>>ss1='Это - строка символов'
|
||||||
|
>>>print(ss1[17:3:-2])
|
||||||
|
омсаот
|
||||||
|
>>>print(ss1[-4:3:-2])
|
||||||
|
омсаот
|
||||||
|
# индексы -4 и 17 обращаются к одному элементу
|
||||||
|
>>>ss1[4]='='
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#41>", line 1, in <module>
|
||||||
|
ss1[4]='='
|
||||||
|
TypeError: 'str' object does not support item assignment
|
||||||
|
>>>ss1=ss1[:4]+'='+ss1[5:]
|
||||||
|
>>>print(ss1)
|
||||||
|
Это = строка символов
|
||||||
|
>>>print(ss1b[22:24]+ss1b[14:21]+ss1b[-1])
|
||||||
|
Я.Мамакин.
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Сложные типы объектов
|
||||||
|
|
||||||
|
Списки:
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>spis1=[111,'Spisok',5-9j]
|
||||||
|
>>>stup=[0,0,1,1,1,1,1,1,1]
|
||||||
|
>>>stup[-8::2]
|
||||||
|
[1, 1, 1, 0] # 7, 5, 3 и 1 индексы
|
||||||
|
>>>spis1[1]='Список'
|
||||||
|
>>>spis1
|
||||||
|
[111, 'Список', (5-9j)]
|
||||||
|
>>>len(spis1)
|
||||||
|
3
|
||||||
|
>>>spis1.append('New item')
|
||||||
|
>>>spis1.append(ss1b)
|
||||||
|
>>>spis1
|
||||||
|
[111, 'Список', (5-9j), 'New item', 'Меня зовут: \n Мамакин Я. Р.']
|
||||||
|
>>>spis1.pop(1)
|
||||||
|
'Список'
|
||||||
|
>>>stup.remove(1)
|
||||||
|
>>>stup.reverse()
|
||||||
|
>>>stup
|
||||||
|
[1, 1, 1, 1, 1, 1, 0, 0]
|
||||||
|
>>>spis2=[spis1,[4,5,6,7]]
|
||||||
|
>>>spis2[0][1]=78
|
||||||
|
>>>spis1
|
||||||
|
[111, 78, 'New item', 'Меня зовут: \n Мамакин Я. Р.']
|
||||||
|
>>>spis3=[56, 'sem-vosem', False, [7, 8]]
|
||||||
|
```
|
||||||
|
|
||||||
|
Кортежи:
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>kort1=(222,'Kortezh',77+8j)
|
||||||
|
>>>kort1= kort1+(1,2)
|
||||||
|
>>>kort2=kort1[:2]+kort1[3:]
|
||||||
|
>>>kort1.index(2)
|
||||||
|
4
|
||||||
|
>>>kort1.count(222)
|
||||||
|
1
|
||||||
|
>>>kort1[2]=90
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#67>", line 1, in <module>
|
||||||
|
kort1[2]=90
|
||||||
|
TypeError: 'tuple' object does not support item assignment
|
||||||
|
>>>kort3=('7-8', 'pyat-shest', (7, 8))
|
||||||
|
>>>kort3
|
||||||
|
('7-8', 'pyat-shest', (7, 8))
|
||||||
|
```
|
||||||
|
|
||||||
|
Словари:
|
||||||
|
|
||||||
|
```py
|
||||||
|
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
|
||||||
|
dic1['Orel']
|
||||||
|
56
|
||||||
|
dic1['Pskov']=78
|
||||||
|
dic1
|
||||||
|
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78}
|
||||||
|
sorted(dic1.keys())
|
||||||
|
['Orel', 'Pskov', 'Saratov', 'Vologda']
|
||||||
|
sorted(dic1.values())
|
||||||
|
[45, 56, 78, 145]
|
||||||
|
dic2={1:'mean',2:'standart deviation',3:'correlation'}
|
||||||
|
dic3={'statistics':dic2,'POAS':['base','elementary','programming']}
|
||||||
|
dic3['statistics'][2]
|
||||||
|
'standart deviation'
|
||||||
|
dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)])
|
||||||
|
dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]))
|
||||||
|
kortn=(7,8,9,10,11,12,13)
|
||||||
|
listn=['sem', 'vosem', 'devyat', 'desyat', 'odinnadsat']
|
||||||
|
dic6=dict(zip(kortn,listn))
|
||||||
|
dic6
|
||||||
|
{7: 'sem', 8: 'vosem', 9: 'devyat', 10: 'desyat', 11: 'odinnadsat'}
|
||||||
|
```
|
||||||
|
Функция zip остановилась на более коротком из итерируемых объектов
|
||||||
|
|
||||||
|
Множества:
|
||||||
|
|
||||||
|
```py
|
||||||
|
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
|
||||||
|
len(mnoz1)
|
||||||
|
4
|
||||||
|
'датчик' in mnoz1
|
||||||
|
True
|
||||||
|
mnoz1.add('реле')
|
||||||
|
mnoz1.remove('линия связи')
|
||||||
|
mno={7, '8', [5, 6]}
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#90>", line 1, in <module>
|
||||||
|
mno={7, '8', [5, 6]}
|
||||||
|
TypeError: unhashable type: 'list'
|
||||||
|
mno={7, '8'}
|
||||||
|
mno.add(7)
|
||||||
|
mno
|
||||||
|
{'8', 7}
|
||||||
|
```
|
||||||
|
Список не может быть элементом множества
|
||||||
|
|
||||||
|
|
||||||
33
TEMA2/task.md
Обычный файл
@@ -0,0 +1,33 @@
|
|||||||
|
# Общее контрольное задание по теме 2
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Реализовать, записать в текстовый файл и проанализировать результаты последовательности ин-струкций, выполняющих следующие действия:
|
||||||
|
• Создать переменную с именем familia и со значением - символьной строкой – своей фами-лией в латинской транскрипции.
|
||||||
|
• Создать переменную со значением, совпадающим с первой буквой из familia.
|
||||||
|
• Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python.
|
||||||
|
• Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка.
|
||||||
|
• Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напи-шите инструкцию, позволяющую убедиться, что тип переменной – это tuple.
|
||||||
|
• Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов.
|
||||||
|
• Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима».
|
||||||
|
• Создайте словарь dict_bas, в котором ключами являются русские названия типов перемен-ных, использованных в предыдущих операторах, а значениями – ранее созданные перемен-ные, соответствующие этим типам.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>familia = 'Мамакин'
|
||||||
|
>>>bukva = familia[0]
|
||||||
|
>>>sp_kw = keyword.kwlist
|
||||||
|
>>>sp_kw.remove('nonlocal')
|
||||||
|
>>>sp_kw
|
||||||
|
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
|
||||||
|
>>>kort_nam = ('Ярослав', 'Дима', 'Семён')
|
||||||
|
>>>type(kort_nam)
|
||||||
|
<class 'tuple'>
|
||||||
|
>>>kort_nam = kort_nam + ('Настя', 'Денис')
|
||||||
|
>>>kort_nam.count('Дима')
|
||||||
|
1
|
||||||
|
>>>dict_bas={'Строка':familia, 'Список':sp_kw, 'Кортеж':kort_nam}
|
||||||
|
```
|
||||||
285
TEMA3/protocol.py
Обычный файл
@@ -0,0 +1,285 @@
|
|||||||
|
|
||||||
|
>>>logiz1=bool(56)
|
||||||
|
>>>logiz2=bool(0)
|
||||||
|
>>>logiz3=bool("Beta")
|
||||||
|
>>>logiz4=bool("")
|
||||||
|
>>>logiz1
|
||||||
|
True
|
||||||
|
>>>logiz2
|
||||||
|
False
|
||||||
|
>>>logiz3
|
||||||
|
True
|
||||||
|
>>>logiz4
|
||||||
|
False
|
||||||
|
>>>tt1=int(198.6)
|
||||||
|
>>>tt2=int("-76")
|
||||||
|
>>>tt3=int("B",16)
|
||||||
|
>>>tt4=int("71",8)
|
||||||
|
>>>tt5=int("98.76")
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#24>", line 1, in <module>
|
||||||
|
tt5=int("98.76")
|
||||||
|
ValueError: invalid literal for int() with base 10: '98.76'
|
||||||
|
>>>tt1
|
||||||
|
198
|
||||||
|
>>>tt2
|
||||||
|
-76
|
||||||
|
>>>tt3
|
||||||
|
11
|
||||||
|
>>>tt4
|
||||||
|
57
|
||||||
|
>>>flt1=float(789)
|
||||||
|
>>>flt2=float(-6.78e2)
|
||||||
|
>>>flt3=float("Infinity")
|
||||||
|
>>>flt4=float("-inf")
|
||||||
|
>>>flt1
|
||||||
|
789.0
|
||||||
|
>>>flt2
|
||||||
|
-678.0
|
||||||
|
>>>flt3
|
||||||
|
inf
|
||||||
|
>>>flt4
|
||||||
|
-inf
|
||||||
|
strk1=str(23.6)
|
||||||
|
strk2=str(logiz3)
|
||||||
|
strk3=str(["A","B","C"])
|
||||||
|
strk4=str(("A","B","C"))
|
||||||
|
strk5=str({"A":1,"B":2,"C":9})
|
||||||
|
spis1=list("Строка символов")
|
||||||
|
spis2=list((124,236,-15,908))
|
||||||
|
spis3=list({"A":1,"B":2,"C":9})
|
||||||
|
kort7=tuple('Строка символов')
|
||||||
|
kort8=tuple(spis2)
|
||||||
|
kort9=tuple({"A":1,"B":2,"C":9})
|
||||||
|
del strk5, kort8
|
||||||
|
dir()
|
||||||
|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'flt1', 'flt2', 'flt3', 'flt4', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'os', 'spis1', 'spis2', 'spis3', 'str1', 'str2', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'u', 'v']
|
||||||
|
imya = 'Мамакин Я. Р.'
|
||||||
|
imya = list(imya)
|
||||||
|
imya = tuple(imya)
|
||||||
|
imya = str(imya)
|
||||||
|
imya
|
||||||
|
"('М', 'а', 'м', 'а', 'к', 'и', 'н', ' ', 'Я', '.', ' ', 'Р', '.')"
|
||||||
|
>>>12+7+90
|
||||||
|
109
|
||||||
|
>>>5.689e-1 - 0.456
|
||||||
|
0.11289999999999994
|
||||||
|
>>>23.6+54
|
||||||
|
77.6
|
||||||
|
>>>14-56.7+89
|
||||||
|
46.3
|
||||||
|
>>>-6.7*12
|
||||||
|
-80.4
|
||||||
|
>>>-234.5/6
|
||||||
|
-39.083333333333336
|
||||||
|
>>>a=178/45
|
||||||
|
>>>a,type(a)
|
||||||
|
(3.9555555555555557, <class 'float'>)
|
||||||
|
>>>b=178//45
|
||||||
|
>>>c=-24.6//12.1
|
||||||
|
>>>b
|
||||||
|
3
|
||||||
|
>>>c
|
||||||
|
-3.0
|
||||||
|
>>>type(b)
|
||||||
|
<class 'int'>
|
||||||
|
>>>type(c)
|
||||||
|
<class 'float'>
|
||||||
|
>>>148%33
|
||||||
|
16
|
||||||
|
>>>12.6%3.8
|
||||||
|
1.2000000000000002
|
||||||
|
>>>14**3
|
||||||
|
2744
|
||||||
|
>>>e=2.7**3.6
|
||||||
|
>>>e
|
||||||
|
35.719843790663525
|
||||||
|
>>>type(e)
|
||||||
|
<class 'float'>
|
||||||
|
>>>f=complex(2+3j)
|
||||||
|
>>>g=f**3.6
|
||||||
|
>>>type(g)
|
||||||
|
<class 'complex'>
|
||||||
|
>>>h=f%5
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#81>", line 1, in <module>
|
||||||
|
h=f%5
|
||||||
|
TypeError: unsupported operand type(s) for %: 'complex' and 'int'
|
||||||
|
>>>h1=f//3
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#82>", line 1, in <module>
|
||||||
|
h1=f//3
|
||||||
|
TypeError: unsupported operand type(s) for //: 'complex' and 'int'
|
||||||
|
>>>dv1=9
|
||||||
|
>>>dv2=~dv1
|
||||||
|
>>>dv2, type(dv2)
|
||||||
|
(-10, <class 'int'>)
|
||||||
|
>>>7&9
|
||||||
|
1
|
||||||
|
>>>7&8
|
||||||
|
0
|
||||||
|
>>>7|9
|
||||||
|
15
|
||||||
|
>>>7|8
|
||||||
|
15
|
||||||
|
>>>14|5
|
||||||
|
15
|
||||||
|
>>>14^5
|
||||||
|
11
|
||||||
|
>>>h=14
|
||||||
|
>>>g=h<<2
|
||||||
|
>>>g1=h>>1
|
||||||
|
>>>g2=h>>2
|
||||||
|
>>>g
|
||||||
|
56
|
||||||
|
>>>g1
|
||||||
|
7
|
||||||
|
>>>g2
|
||||||
|
3
|
||||||
|
>>>255^128
|
||||||
|
127 # 11111111 искл. ИЛИ 10000000 = 1111111
|
||||||
|
>>>'Система '+'регулирования'
|
||||||
|
'Система регулирования'
|
||||||
|
>>>['abc','de','fg']+['hi','jkl']
|
||||||
|
['abc', 'de', 'fg', 'hi', 'jkl']
|
||||||
|
>>>('abc','de','fg')+('hi','jkl')
|
||||||
|
('abc', 'de', 'fg', 'hi', 'jkl')
|
||||||
|
>>>'ля-'*5
|
||||||
|
'ля-ля-ля-ля-ля-'
|
||||||
|
>>>['ку','-']*3
|
||||||
|
['ку', '-', 'ку', '-', 'ку', '-']
|
||||||
|
>>>('кис','-')*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)
|
||||||
|
>>>stroka='Система автоматического управления'
|
||||||
|
>>>'автомат' in stroka
|
||||||
|
True
|
||||||
|
>>>'ку' in ['ку','-']*3
|
||||||
|
True
|
||||||
|
>>>'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl')
|
||||||
|
False
|
||||||
|
>>>stroka='Температура = %g %s %g'
|
||||||
|
>>>stroka % (16,' меньше ',25)
|
||||||
|
'Температура = 16 меньше 25'
|
||||||
|
>>>stroka='Температура = %(zn1)g %(sravn)s %(zn2)g'
|
||||||
|
>>>stroka % {'zn1':16,'sravn':' меньше ','zn2':25}
|
||||||
|
'Температура = 16 меньше 25'
|
||||||
|
>>>zz=-12
|
||||||
|
>>>zz+=5
|
||||||
|
>>>zz-=3
|
||||||
|
>>>stroka='Система'
|
||||||
|
>>>stroka+=' регулирования'
|
||||||
|
>>>stroka
|
||||||
|
'Система регулирования'
|
||||||
|
>>>zz*=5
|
||||||
|
>>>s='s'
|
||||||
|
>>>s*=5
|
||||||
|
>>>s
|
||||||
|
'sssss'
|
||||||
|
>>>zz
|
||||||
|
-25.0
|
||||||
|
>>>zz//=4
|
||||||
|
>>>zz
|
||||||
|
-7.0
|
||||||
|
>>>zz%=3
|
||||||
|
>>>zz
|
||||||
|
2.0
|
||||||
|
>>>zz**=5
|
||||||
|
>>>zz
|
||||||
|
32.0
|
||||||
|
>>>w=v=10
|
||||||
|
>>>n1,n2,n3=(11,-3,'all')
|
||||||
|
>>>n1,n2,n3=[1,2,3] # можно
|
||||||
|
>>>n1,n2,n3={1:'a',2:'b',3:'c'} # можно
|
||||||
|
>>>n1
|
||||||
|
1
|
||||||
|
>>>w<=v
|
||||||
|
True
|
||||||
|
>>>w==v
|
||||||
|
True
|
||||||
|
>>>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=17
|
||||||
|
>>>b=-6
|
||||||
|
>>>(a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1)
|
||||||
|
True
|
||||||
|
>>>(b>=a) or not ('pen' in dic1)
|
||||||
|
True
|
||||||
|
>>>w is v
|
||||||
|
True
|
||||||
|
>>>w1=['A','B']
|
||||||
|
>>>v1=['A','B']
|
||||||
|
>>>w1 is v1
|
||||||
|
False
|
||||||
|
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']
|
||||||
|
stroka.find('пр')
|
||||||
|
5
|
||||||
|
stroka.count("с")
|
||||||
|
4
|
||||||
|
stroka.replace(' у',' автоматического у')
|
||||||
|
'Микропроцессорная система автоматического управления'
|
||||||
|
spis22=stroka.split(' ')
|
||||||
|
stroka.upper()
|
||||||
|
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
|
||||||
|
stroka3=" ".join(spis22)
|
||||||
|
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'
|
||||||
|
spsk = [1,2,3,4,5,6]
|
||||||
|
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 = [1,2,3,4,5,6]
|
||||||
|
spsk.pop(2)
|
||||||
|
3
|
||||||
|
spsk.append('c')
|
||||||
|
spsk
|
||||||
|
[1, 2, 4, 5, 6, 'c']
|
||||||
|
spsk.insert(2,'a')
|
||||||
|
spsk
|
||||||
|
[1, 2, 'a', 4, 5, 6, 'c']
|
||||||
|
spsk.count('a')
|
||||||
|
1
|
||||||
|
kort = (1,2)
|
||||||
|
dir(kort)
|
||||||
|
['__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']
|
||||||
|
len(kort)
|
||||||
|
2
|
||||||
|
dict1={1:'a',2:'b',3:'c'}
|
||||||
|
dir(dict1)
|
||||||
|
['__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']
|
||||||
|
dict1.popitem()
|
||||||
|
(3, 'c')
|
||||||
|
|
||||||
|
|
||||||
492
TEMA3/report.md
Обычный файл
@@ -0,0 +1,492 @@
|
|||||||
|
# Отчет по теме 3
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку.
|
||||||
|
|
||||||
|
## 2 Преобразование простых базовых типов объектов
|
||||||
|
|
||||||
|
## 2.1 Преобразование в логический тип с помощью функции bool(<Объект>)
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>logiz1=bool(56)
|
||||||
|
>>>logiz2=bool(0)
|
||||||
|
>>>logiz3=bool("Beta")
|
||||||
|
>>>logiz4=bool("")
|
||||||
|
>>>logiz1
|
||||||
|
True
|
||||||
|
>>>logiz2
|
||||||
|
False
|
||||||
|
>>>logiz3
|
||||||
|
True
|
||||||
|
>>>logiz4
|
||||||
|
False
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.2 Преобразование в число
|
||||||
|
|
||||||
|
В тип int
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>tt1=int(198.6)
|
||||||
|
>>>tt2=int("-76")
|
||||||
|
>>>tt3=int("B",16)
|
||||||
|
>>>tt4=int("71",8)
|
||||||
|
>>>tt5=int("98.76")
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#24>", line 1, in <module>
|
||||||
|
tt5=int("98.76")
|
||||||
|
ValueError: invalid literal for int() with base 10: '98.76'
|
||||||
|
>>>tt1
|
||||||
|
198
|
||||||
|
>>>tt2
|
||||||
|
-76
|
||||||
|
>>>tt3
|
||||||
|
11
|
||||||
|
>>>tt4
|
||||||
|
57
|
||||||
|
```
|
||||||
|
|
||||||
|
В тип float
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>flt1=float(789)
|
||||||
|
>>>flt2=float(-6.78e2)
|
||||||
|
>>>flt3=float("Infinity")
|
||||||
|
>>>flt4=float("-inf")
|
||||||
|
>>>flt1
|
||||||
|
789.0
|
||||||
|
>>>flt2
|
||||||
|
-678.0
|
||||||
|
>>>flt3
|
||||||
|
inf
|
||||||
|
>>>flt4
|
||||||
|
-inf
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Изучите преобразования более сложных базовых типов объектов.
|
||||||
|
|
||||||
|
## 3.1 Преобразование в строку
|
||||||
|
|
||||||
|
```py
|
||||||
|
strk1=str(23.6)
|
||||||
|
strk2=str(logiz3)
|
||||||
|
strk3=str(["A","B","C"])
|
||||||
|
strk4=str(("A","B","C"))
|
||||||
|
strk5=str({"A":1,"B":2,"C":9})
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.2 Преобразование в список
|
||||||
|
|
||||||
|
```py
|
||||||
|
spis1=list("Строка символов")
|
||||||
|
spis2=list((124,236,-15,908))
|
||||||
|
spis3=list({"A":1,"B":2,"C":9})
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.3 В кортеж
|
||||||
|
|
||||||
|
```py
|
||||||
|
kort7=tuple('Строка символов')
|
||||||
|
kort8=tuple(spis2)
|
||||||
|
kort9=tuple({"A":1,"B":2,"C":9})
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.4 Удаление объектов
|
||||||
|
|
||||||
|
```py
|
||||||
|
del strk5, kort8
|
||||||
|
dir()
|
||||||
|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'flt1', 'flt2', 'flt3', 'flt4', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'os', 'spis1', 'spis2', 'spis3', 'str1', 'str2', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'u', 'v']
|
||||||
|
imya = 'Мамакин Я. Р.'
|
||||||
|
imya = list(imya)
|
||||||
|
imya = tuple(imya)
|
||||||
|
imya = str(imya)
|
||||||
|
imya
|
||||||
|
"('М', 'а', 'м', 'а', 'к', 'и', 'н', ' ', 'Я', '.', ' ', 'Р', '.')"
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Арифметические операции
|
||||||
|
|
||||||
|
## 4.1 Сложение и вычитание
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>12+7+90
|
||||||
|
109
|
||||||
|
>>>5.689e-1 - 0.456
|
||||||
|
0.11289999999999994
|
||||||
|
>>>23.6+54
|
||||||
|
77.6
|
||||||
|
>>>14-56.7+89
|
||||||
|
46.3
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.2 Умножение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>-6.7*12
|
||||||
|
-80.4
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.3 Деление
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>-234.5/6
|
||||||
|
-39.083333333333336
|
||||||
|
>>>a=178/45
|
||||||
|
>>>a,type(a)
|
||||||
|
(3.9555555555555557, <class 'float'>)
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.4 Деление с округлением вниз
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>b=178//45
|
||||||
|
>>>c=-24.6//12.1
|
||||||
|
>>>b
|
||||||
|
3
|
||||||
|
>>>c
|
||||||
|
-3.0
|
||||||
|
>>>type(b)
|
||||||
|
<class 'int'>
|
||||||
|
>>>type(c)
|
||||||
|
<class 'float'>
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.5 Взятие остатка от деления
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>148%33
|
||||||
|
16
|
||||||
|
>>>12.6%3.8
|
||||||
|
1.2000000000000002
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.6 Возведение в степень
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>14**3
|
||||||
|
2744
|
||||||
|
>>>e=2.7**3.6
|
||||||
|
>>>e
|
||||||
|
35.719843790663525
|
||||||
|
>>>type(e)
|
||||||
|
<class 'float'>
|
||||||
|
>>>f=complex(2+3j)
|
||||||
|
>>>g=f**3.6
|
||||||
|
>>>type(g)
|
||||||
|
<class 'complex'>
|
||||||
|
>>>h=f%5
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#81>", line 1, in <module>
|
||||||
|
h=f%5
|
||||||
|
TypeError: unsupported operand type(s) for %: 'complex' and 'int'
|
||||||
|
>>>h1=f//3
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#82>", line 1, in <module>
|
||||||
|
h1=f//3
|
||||||
|
TypeError: unsupported operand type(s) for //: 'complex' and 'int'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5 Операции с двоичными числами
|
||||||
|
|
||||||
|
## 5.1 Инверсия
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>dv1=9
|
||||||
|
>>>dv2=~dv1
|
||||||
|
>>>dv2, type(dv2)
|
||||||
|
(-10, <class 'int'>)
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5.2 Логическое И
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>7&9
|
||||||
|
1
|
||||||
|
>>>7&8
|
||||||
|
0
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5.3 Логическое ИЛИ
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>7|9
|
||||||
|
15
|
||||||
|
>>>7|8
|
||||||
|
15
|
||||||
|
>>>14|5
|
||||||
|
15
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5.4 Исключающее или
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>14^5
|
||||||
|
11
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5.5 Сдвиг разрядов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>h=14
|
||||||
|
>>>g=h<<2
|
||||||
|
>>>g1=h>>1
|
||||||
|
>>>g2=h>>2
|
||||||
|
>>>g
|
||||||
|
56
|
||||||
|
>>>g1
|
||||||
|
7
|
||||||
|
>>>g2
|
||||||
|
3
|
||||||
|
>>>255^128
|
||||||
|
127 # 11111111 искл. ИЛИ 10000000 = 1111111
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Операции при работе с последовательностями (строками, списками, кортежами)
|
||||||
|
|
||||||
|
## 6.1 Конкатенация
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>'Система '+'регулирования'
|
||||||
|
'Система регулирования'
|
||||||
|
>>>['abc','de','fg']+['hi','jkl']
|
||||||
|
['abc', 'de', 'fg', 'hi', 'jkl']
|
||||||
|
>>>('abc','de','fg')+('hi','jkl')
|
||||||
|
('abc', 'de', 'fg', 'hi', 'jkl')
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6.2 Повторение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>'ля-'*5
|
||||||
|
'ля-ля-ля-ля-ля-'
|
||||||
|
>>>['ку','-']*3
|
||||||
|
['ку', '-', 'ку', '-', 'ку', '-']
|
||||||
|
>>>('кис','-')*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 Проверка вхождения
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>stroka='Система автоматического управления'
|
||||||
|
>>>'автомат' in stroka
|
||||||
|
True
|
||||||
|
>>>'ку' in ['ку','-']*3
|
||||||
|
True
|
||||||
|
>>>'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl')
|
||||||
|
False
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6.4 Подстановка значений
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>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 Обычное
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>zz=-12
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7.2 Увеличение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>zz+=5
|
||||||
|
>>>zz-=3
|
||||||
|
>>>stroka='Система'
|
||||||
|
>>>stroka+=' регулирования'
|
||||||
|
>>>stroka
|
||||||
|
'Система регулирования'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7.3 Умножение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>zz*=5
|
||||||
|
>>>s='s'
|
||||||
|
>>>s*=5
|
||||||
|
>>>s
|
||||||
|
'sssss'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7.4 Деление с округлением, остаток, степень
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>zz
|
||||||
|
-25.0
|
||||||
|
>>>zz//=4
|
||||||
|
>>>zz
|
||||||
|
-7.0
|
||||||
|
>>>zz%=3
|
||||||
|
>>>zz
|
||||||
|
2.0
|
||||||
|
>>>zz**=5
|
||||||
|
>>>zz
|
||||||
|
32.0
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7.5 Множественное присваивание
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>w=v=10
|
||||||
|
>>>n1,n2,n3=(11,-3,'all')
|
||||||
|
>>>n1,n2,n3=[1,2,3] # можно
|
||||||
|
>>>n1,n2,n3={1:'a',2:'b',3:'c'} # можно
|
||||||
|
>>>n1
|
||||||
|
1
|
||||||
|
```
|
||||||
|
|
||||||
|
## 8 Логические операции
|
||||||
|
|
||||||
|
## 8.1 Сравнение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>w<=v
|
||||||
|
True
|
||||||
|
>>>w==v
|
||||||
|
True
|
||||||
|
```
|
||||||
|
|
||||||
|
## 8.2 Проверка наличия
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>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 Создание больших логических выражений
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>a=17
|
||||||
|
>>>b=-6
|
||||||
|
>>>(a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1)
|
||||||
|
True
|
||||||
|
>>>(b>=a) or not ('pen' in dic1)
|
||||||
|
True
|
||||||
|
```
|
||||||
|
|
||||||
|
## 8.4 Проверка совпадения ссылок на объект
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>w is v
|
||||||
|
True
|
||||||
|
>>>w1=['A','B']
|
||||||
|
>>>v1=['A','B']
|
||||||
|
>>>w1 is v1
|
||||||
|
False
|
||||||
|
```
|
||||||
|
w1 и v1 идентичные, но отдельные объекты. w и v ссылаются на один объект
|
||||||
|
|
||||||
|
## 9 Применение методов к объектам
|
||||||
|
|
||||||
|
## 9.1 Работа со строками
|
||||||
|
|
||||||
|
```py
|
||||||
|
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']
|
||||||
|
stroka.find('пр')
|
||||||
|
5
|
||||||
|
stroka.count("с")
|
||||||
|
4
|
||||||
|
stroka.replace(' у',' автоматического у')
|
||||||
|
'Микропроцессорная система автоматического управления'
|
||||||
|
spis22=stroka.split(' ')
|
||||||
|
stroka.upper()
|
||||||
|
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
|
||||||
|
stroka3=" ".join(spis22)
|
||||||
|
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 Работа со списками
|
||||||
|
|
||||||
|
```py
|
||||||
|
spsk = [1,2,3,4,5,6]
|
||||||
|
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 = [1,2,3,4,5,6]
|
||||||
|
spsk.pop(2)
|
||||||
|
3
|
||||||
|
spsk.append('c')
|
||||||
|
spsk
|
||||||
|
[1, 2, 4, 5, 6, 'c']
|
||||||
|
spsk.insert(2,'a')
|
||||||
|
spsk
|
||||||
|
[1, 2, 'a', 4, 5, 6, 'c']
|
||||||
|
spsk.count('a')
|
||||||
|
1
|
||||||
|
```
|
||||||
|
|
||||||
|
## 9.3 Работа с кортежами
|
||||||
|
|
||||||
|
```py
|
||||||
|
kort = (1,2)
|
||||||
|
dir(kort)
|
||||||
|
['__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']
|
||||||
|
len(kort)
|
||||||
|
2
|
||||||
|
```
|
||||||
|
|
||||||
|
## 9.4 Работа со словарями
|
||||||
|
|
||||||
|
```py
|
||||||
|
dict1={1:'a',2:'b',3:'c'}
|
||||||
|
dir(dict1)
|
||||||
|
['__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']
|
||||||
|
dict1.popitem()
|
||||||
|
(3, 'c')
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
48
TEMA3/task.md
Обычный файл
@@ -0,0 +1,48 @@
|
|||||||
|
# Общее контрольное задание по теме 3
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Реализовать, записать в текстовый файл и проанализировать результаты последовательности ин-струкций, выполняющих следующие действия:
|
||||||
|
• Преобразовать восьмеричное значение 45 в целое число.
|
||||||
|
• Создать объект-словарь D со значениями {"усиление":23, "запаздывание":12, "постоянная вре-мени":78} и затем осуществить его преобразование в два списка: ключей и значений, а затем – эти два списка преобразовать в один кортеж. Чем отличается кортеж от списка?
|
||||||
|
• Напишите и выполните единое выражение, осуществляющее деление числа 1768 на 24.8 с округлением вниз, с определением после этого остатка от деления получившегося значения на 3 и затем возведения результата в степень 2.4.
|
||||||
|
• Напишите и выполните единое выражение, последовательно осуществляющее следующие опе-рации: двоичное И для чисел 13 и 27, инверсия полученного значения, двоичное исключающее ИЛИ для полученного значения и числа 14, сдвиг полученного значения на два разряда влево.
|
||||||
|
• Создать список с 4 одинаковыми элементами 'колебат' и написать оператор проверки наличия комбинации символов 'аткол' в результате конкатенации второго и третьего элементов этого списка.
|
||||||
|
• Определить список методов, доступных у ранее созданного словаря D. Поочередно использо-вать его методы keys и values, определить, что можно получить с применением этих методов.
|
||||||
|
• Создать объект - символьную строку с текстом данного предложения. Из символьной строки создать список, элементами которого будут отдельные слова из созданной строки. Заменить в списке элемент «-» на «,». Удалить из списка элемент со значением «данного». Отобразить получившийся список.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
zn = "45"
|
||||||
|
zn1 = int(zn, 8)
|
||||||
|
zn1
|
||||||
|
37
|
||||||
|
D = {"усиление":23, "запаздывание":12, "постоянная времени":78}
|
||||||
|
keys_D = list(D.keys())
|
||||||
|
values_D = list(D.values())
|
||||||
|
kort = tuple(keys_D + values_D)
|
||||||
|
kort
|
||||||
|
('усиление', 'запаздывание', 'постоянная времени', 23, 12, 78)
|
||||||
|
((1768 // 24.8) % 3) ** 2.4
|
||||||
|
5.278031643091577
|
||||||
|
((~(13&27))^14)<<2
|
||||||
|
-32
|
||||||
|
spi = ['колебат', 'колебат', 'колебат', 'колебат']
|
||||||
|
'аткол' in (spi[1] + spi[2])
|
||||||
|
True
|
||||||
|
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']
|
||||||
|
type(D.keys())
|
||||||
|
<class 'dict_keys'>
|
||||||
|
type(D.values())
|
||||||
|
<class 'dict_values'>
|
||||||
|
st = 'Создать объект - символьную строку с текстом данного предложения.'
|
||||||
|
st1 = st.split()
|
||||||
|
st1[2] = ','
|
||||||
|
del st1[7]
|
||||||
|
st1
|
||||||
|
['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'предложения.']
|
||||||
|
```
|
||||||
61
TEMA3/test.md
Обычный файл
@@ -0,0 +1,61 @@
|
|||||||
|
# Тест по модулю 1
|
||||||
|
|
||||||
|
Мамакин Ярослав Романович
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
M1_7
|
||||||
|
1) Можно ли работать со средой без использования интерактивной оболочки IDLE?
|
||||||
|
|
||||||
|
2) Создайте объект-словарь с 7 элементами: ключи - названия (аббревиатура) вузов, значения - число студентов (задать произвольно). Напишите инструкцию, доказывающую, что создан объект именно требуемого типа. Напишите инструкцию отображения списка атрибутов созданного объекта.
|
||||||
|
|
||||||
|
3) Напишите инструкцию, позволяющую вычислить общее число студентов в двух указываемых вузах из словаря.
|
||||||
|
|
||||||
|
4) Преобразуйте значения из словаря в список и, затем, список - в строку. Отобразите полученные объекты. Получите новый список, разделением строки на части по разделителю: ",".
|
||||||
|
|
||||||
|
5) Используя операцию подстановки, отобразить рассчитанное число студентов в 2-х вузах по шаблону: "Число студентов в <название вуза 1> и <название вуза 2> =:".
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
1) Можно, используя командную строку
|
||||||
|
|
||||||
|
2)
|
||||||
|
```py
|
||||||
|
slov={'МЭИ':1500,'МГУ':4000,'МГТУ':3000,'МИРЭА':950,'ВШЭ':3500,'МГИМО':1700,'МТУСИ':3}
|
||||||
|
type(slov)
|
||||||
|
<class 'dict'>
|
||||||
|
dir(slov)
|
||||||
|
['__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']
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
3)
|
||||||
|
```py
|
||||||
|
print(slov[str(input("Введите 1-й вуз"))] + slov[str(input("Введите 2-й вуз"))])
|
||||||
|
Введите 1-й вузМЭИ
|
||||||
|
Введите 2-й вузВШЭ
|
||||||
|
5000
|
||||||
|
```
|
||||||
|
|
||||||
|
4)
|
||||||
|
```py
|
||||||
|
spis=list(slov)
|
||||||
|
spis
|
||||||
|
['МЭИ', 'МГУ', 'МГТУ', 'МИРЭА', 'ВШЭ', 'МГИМО', 'МТУСИ']
|
||||||
|
strok = str(spis)
|
||||||
|
strok
|
||||||
|
"['МЭИ', 'МГУ', 'МГТУ', 'МИРЭА', 'ВШЭ', 'МГИМО', 'МТУСИ']"
|
||||||
|
spis2 = strok.split(",")
|
||||||
|
spis2
|
||||||
|
["['МЭИ'", " 'МГУ'", " 'МГТУ'", " 'МИРЭА'", " 'ВШЭ'", " 'МГИМО'", " 'МТУСИ']"]
|
||||||
|
```
|
||||||
|
|
||||||
|
5)
|
||||||
|
```py
|
||||||
|
vuz1=input("Введите 1-й вуз")
|
||||||
|
Введите 1-й вузМЭИ
|
||||||
|
vuz2=input("Введите 2-й вуз")
|
||||||
|
Введите 2-й вузМТУСИ
|
||||||
|
print(f"Число студентов в {vuz1} и {vuz2} =: {slov[vuz1] + slov[vuz2]}")
|
||||||
|
Число студентов в МЭИ и МТУСИ =: 1503
|
||||||
|
```
|
||||||
Двоичные данные
TEMA4/Ris1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 20 KiB |
Двоичные данные
TEMA4/Ris2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 15 KiB |
Двоичные данные
TEMA4/Ris3.png
Обычный файл
|
После Ширина: | Высота: | Размер: 9.9 KiB |
Двоичные данные
TEMA4/Ris4.png
Обычный файл
|
После Ширина: | Высота: | Размер: 6.5 KiB |
Двоичные данные
TEMA4/Ris_1.1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 26 KiB |
287
TEMA4/protocol.py
Обычный файл
@@ -0,0 +1,287 @@
|
|||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA4')
|
||||||
|
help round
|
||||||
|
SyntaxError: invalid syntax
|
||||||
|
help(round)
|
||||||
|
Help on built-in function round in module builtins:
|
||||||
|
|
||||||
|
round(number, ndigits=None)
|
||||||
|
Round a number to a given precision in decimal digits.
|
||||||
|
|
||||||
|
The return value is an integer if ndigits is omitted or None. Otherwise
|
||||||
|
the return value has the same type as the number. ndigits may be negative.
|
||||||
|
|
||||||
|
round(123,456,1)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#4>", line 1, in <module>
|
||||||
|
round(123,456,1)
|
||||||
|
TypeError: round() takes at most 2 arguments (3 given)
|
||||||
|
round(123.456,1)
|
||||||
|
123.5
|
||||||
|
round(123.456,0)
|
||||||
|
123.0
|
||||||
|
round(123.456)
|
||||||
|
123
|
||||||
|
gg=range(76, 123, 9)
|
||||||
|
type(gg)
|
||||||
|
<class 'range'>
|
||||||
|
list(gg)
|
||||||
|
[76, 85, 94, 103, 112, 121]
|
||||||
|
range(23)
|
||||||
|
range(0, 23)
|
||||||
|
qq = ['Мамакин','Савин','Симанков','Киреев']
|
||||||
|
ff=zip(gg,qq)
|
||||||
|
tuple(ff)
|
||||||
|
((76, 'Мамакин'), (85, 'Савин'), (94, 'Симанков'), (103, 'Киреев'))
|
||||||
|
ff[1]
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#15>", line 1, in <module>
|
||||||
|
ff[1]
|
||||||
|
TypeError: 'zip' object is not subscriptable
|
||||||
|
fff=float(input('коэффициент усиления='))
|
||||||
|
коэффициент усиления=54
|
||||||
|
dan=eval('5*fff-156')
|
||||||
|
dan
|
||||||
|
114.0
|
||||||
|
exec(input('введите инструкции:'))
|
||||||
|
введите инструкции:perem=-123.456;gg=round(abs(perem)+98,3)
|
||||||
|
gg
|
||||||
|
221.456
|
||||||
|
list(map(len, qq))
|
||||||
|
[7, 5, 8, 6]
|
||||||
|
divmod(64,5)
|
||||||
|
(12, 4)
|
||||||
|
import math
|
||||||
|
dir(math)
|
||||||
|
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atan2', 'atanh', 'cbrt', 'ceil', 'comb', 'copysign', 'cos', 'cosh', 'degrees', 'dist', 'e', 'erf', 'erfc', 'exp', 'exp2', 'expm1', 'fabs', 'factorial', 'floor', 'fma', 'fmod', 'frexp', 'fsum', 'gamma', 'gcd', 'hypot', 'inf', 'isclose', 'isfinite', 'isinf', 'isnan', 'isqrt', 'lcm', 'ldexp', 'lgamma', 'log', 'log10', 'log1p', 'log2', 'modf', 'nan', 'nextafter', 'perm', 'pi', 'pow', 'prod', 'radians', 'remainder', 'sin', 'sinh', 'sqrt', 'sumprod', 'tan', 'tanh', 'tau', 'trunc', 'ulp']
|
||||||
|
help(math.factorial)
|
||||||
|
Help on built-in function factorial in module math:
|
||||||
|
|
||||||
|
factorial(n, /)
|
||||||
|
Find n!.
|
||||||
|
|
||||||
|
math.factorial(5)
|
||||||
|
120
|
||||||
|
math.degrees(math.acos(math.sin(math.pi)))
|
||||||
|
90.0
|
||||||
|
math.sin(2*math.pi / 7 + math.exp(0.23))
|
||||||
|
0.8334902641414562
|
||||||
|
import cmath
|
||||||
|
dir(cmath)
|
||||||
|
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atanh', 'cos', 'cosh', 'e', 'exp', 'inf', 'infj', 'isclose', 'isfinite', 'isinf', 'isnan', 'log', 'log10', 'nan', 'nanj', 'phase', 'pi', 'polar', 'rect', 'sin', 'sinh', 'sqrt', 'tan', 'tanh', 'tau']
|
||||||
|
cmath.sqrt(1.2-0.5j)
|
||||||
|
(1.118033988749895-0.22360679774997896j)
|
||||||
|
cmath.phase(1-0.5j)
|
||||||
|
-0.4636476090008061
|
||||||
|
import random
|
||||||
|
dir(random)
|
||||||
|
['BPF', 'LOG4', 'NV_MAGICCONST', 'RECIP_BPF', 'Random', 'SG_MAGICCONST', 'SystemRandom', 'TWOPI', '_ONE', '_Sequence', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_accumulate', '_acos', '_bisect', '_ceil', '_cos', '_e', '_exp', '_fabs', '_floor', '_index', '_inst', '_isfinite', '_lgamma', '_log', '_log2', '_os', '_parse_args', '_pi', '_random', '_repeat', '_sha512', '_sin', '_sqrt', '_test', '_test_generator', '_urandom', 'betavariate', 'binomialvariate', 'choice', 'choices', 'expovariate', 'gammavariate', 'gauss', 'getrandbits', 'getstate', 'lognormvariate', 'main', 'normalvariate', 'paretovariate', 'randbytes', 'randint', 'random', 'randrange', 'sample', 'seed', 'setstate', 'shuffle', 'triangular', 'uniform', 'vonmisesvariate', 'weibullvariate']
|
||||||
|
help(random.seed())
|
||||||
|
Help on NoneType object:
|
||||||
|
|
||||||
|
class NoneType(object)
|
||||||
|
| The type of the None singleton.
|
||||||
|
|
|
||||||
|
| Methods defined here:
|
||||||
|
|
|
||||||
|
| __bool__(self, /)
|
||||||
|
| True if self else False
|
||||||
|
|
|
||||||
|
| __eq__(self, value, /)
|
||||||
|
| Return self==value.
|
||||||
|
|
|
||||||
|
| __ge__(self, value, /)
|
||||||
|
| Return self>=value.
|
||||||
|
|
|
||||||
|
| __gt__(self, value, /)
|
||||||
|
| Return self>value.
|
||||||
|
|
|
||||||
|
| __hash__(self, /)
|
||||||
|
| Return hash(self).
|
||||||
|
|
|
||||||
|
| __le__(self, value, /)
|
||||||
|
| Return self<=value.
|
||||||
|
|
|
||||||
|
| __lt__(self, value, /)
|
||||||
|
| Return self<value.
|
||||||
|
|
|
||||||
|
| __ne__(self, value, /)
|
||||||
|
| Return self!=value.
|
||||||
|
|
|
||||||
|
| __repr__(self, /)
|
||||||
|
| Return repr(self).
|
||||||
|
|
|
||||||
|
| ----------------------------------------------------------------------
|
||||||
|
| Static methods defined here:
|
||||||
|
|
|
||||||
|
| __new__(*args, **kwargs)
|
||||||
|
| Create and return a new object. See help(type) for accurate signature.
|
||||||
|
|
||||||
|
random.seed()
|
||||||
|
random.random()
|
||||||
|
0.6216104315561441
|
||||||
|
random.uniform()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#38>", line 1, in <module>
|
||||||
|
random.uniform()
|
||||||
|
TypeError: Random.uniform() missing 2 required positional arguments: 'a' and 'b'
|
||||||
|
random.uniform(0,1)
|
||||||
|
0.15558476742451
|
||||||
|
random.randint()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#40>", line 1, in <module>
|
||||||
|
random.randint()
|
||||||
|
TypeError: Random.randint() missing 2 required positional arguments: 'a' and 'b'
|
||||||
|
random.randint(0,100)
|
||||||
|
65
|
||||||
|
random.gauss()
|
||||||
|
-1.2490453714301064
|
||||||
|
random.choice([1,2,3,4,5])
|
||||||
|
5
|
||||||
|
random.shuffle([1,2,3,4,5])
|
||||||
|
sp = [1,2,3,4,5,6,7,8,9]
|
||||||
|
random.shuffle(sp)
|
||||||
|
sp
|
||||||
|
[8, 2, 5, 9, 6, 7, 1, 3, 4]
|
||||||
|
random.sample(sp, 3)
|
||||||
|
[6, 1, 7]
|
||||||
|
random.betavariate()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#49>", line 1, in <module>
|
||||||
|
random.betavariate()
|
||||||
|
TypeError: Random.betavariate() missing 2 required positional arguments: 'alpha' and 'beta'
|
||||||
|
random.betavariate(0.5, 0.5)
|
||||||
|
0.21196520335129634
|
||||||
|
random.gammavariate(0.5, 0.5)
|
||||||
|
0.18678325471924362
|
||||||
|
sp1 = [random.random(), random.gauss(), random.betavariate(0.5,0.5), random.gammavariate(0.5, 0.5)]
|
||||||
|
sp1
|
||||||
|
[0.09352103273802048, 0.41529631729753796, 0.5372987697985309, 0.08540638796369146]
|
||||||
|
import time
|
||||||
|
dir(time)
|
||||||
|
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'monotonic_ns', 'perf_counter', 'perf_counter_ns', 'process_time', 'process_time_ns', 'sleep', 'strftime', 'strptime', 'struct_time', 'thread_time', 'thread_time_ns', 'time', 'time_ns', 'timezone', 'tzname']
|
||||||
|
c1=time.time()
|
||||||
|
c2=time.time()-c1
|
||||||
|
c2
|
||||||
|
13.89244294166565
|
||||||
|
dat = time.gmtime()
|
||||||
|
dat.tm_mon()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#60>", line 1, in <module>
|
||||||
|
dat.tm_mon()
|
||||||
|
TypeError: 'int' object is not callable
|
||||||
|
dat.tm_mon
|
||||||
|
9
|
||||||
|
dat1 = time.localtime()
|
||||||
|
dat1.tm_day
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#63>", line 1, in <module>
|
||||||
|
dat1.tm_day
|
||||||
|
AttributeError: 'time.struct_time' object has no attribute 'tm_day'. Did you mean: 'tm_mday'?
|
||||||
|
dit1.tm_mday
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#64>", line 1, in <module>
|
||||||
|
dit1.tm_mday
|
||||||
|
NameError: name 'dit1' is not defined. Did you mean: 'dat1'?
|
||||||
|
dat1.tm_mday
|
||||||
|
28
|
||||||
|
time.asctime(dat)
|
||||||
|
'Sat Sep 27 21:23:38 2025'
|
||||||
|
time.ctime(564783)
|
||||||
|
'Wed Jan 7 15:53:03 1970'
|
||||||
|
time.mktime(dat1)
|
||||||
|
1759008378.0
|
||||||
|
time.localtime(c1)
|
||||||
|
time.struct_time(tm_year=2025, tm_mon=9, tm_mday=28, tm_hour=0, tm_min=22, tm_sec=49, tm_wday=6, tm_yday=271, tm_isdst=0)
|
||||||
|
import pylab
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#70>", line 1, in <module>
|
||||||
|
import pylab
|
||||||
|
ModuleNotFoundError: No module named 'pylab'
|
||||||
|
import sys
|
||||||
|
sys.path.append('C:\Users\uprkt\AppData\Local\Programs\Python\Python313\\lib\\site-packages')
|
||||||
|
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape
|
||||||
|
sys.path.append(‘C:\Users\uprkt\AppData\Local\Programs\Python\Python313\\lib\\site-packages’)
|
||||||
|
SyntaxError: invalid character '‘' (U+2018)
|
||||||
|
sys.path.append(r‘C:\Users\uprkt\AppData\Local\Programs\Python\Python313\\lib\\site-packages’)
|
||||||
|
SyntaxError: invalid character '‘' (U+2018)
|
||||||
|
sys.path.append(r'C:\Users\uprkt\AppData\Local\Programs\Python\Python313\\lib\\site-packages')
|
||||||
|
import pylab
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#76>", line 1, in <module>
|
||||||
|
import pylab
|
||||||
|
ModuleNotFoundError: No module named 'pylab'
|
||||||
|
import pylab
|
||||||
|
x=list(range(-3,55,4))
|
||||||
|
t=list(range(15))
|
||||||
|
pylab.plot(t,x)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE16E6850>]
|
||||||
|
pylab.title('Первый график')
|
||||||
|
Text(0.5, 1.0, 'Первый график')
|
||||||
|
pylab.xlabel('время')
|
||||||
|
Text(0.5, 0, 'время')
|
||||||
|
pylab.ylabel('сигнал')
|
||||||
|
Text(0, 0.5, 'сигнал')
|
||||||
|
pylab.show()
|
||||||
|
X1=[12,6,8,10,7]
|
||||||
|
X2=[5,7,9,11,13]
|
||||||
|
pylab.plot(X1)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE37DB110>]
|
||||||
|
pylab.plot(X2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE37DB250>]
|
||||||
|
pylab.show()
|
||||||
|
region=['Центр','Урал','Сибирь','Юг']
|
||||||
|
naselen=[65,12,23,17]
|
||||||
|
pylab.pie(naselen,labels=region)
|
||||||
|
([<matplotlib.patches.Wedge object at 0x0000020CE16C9940>, <matplotlib.patches.Wedge object at 0x0000020CE1EBCB90>, <matplotlib.patches.Wedge object at 0x0000020CE1EBCF50>, <matplotlib.patches.Wedge object at 0x0000020CE1EBD1D0>], [Text(-0.191013134139045, 1.0832885038559115, 'Центр'), Text(-0.861328292412156, -0.6841882582231001, 'Урал'), Text(0.04429273995539947, -1.0991078896938387, 'Сибирь'), Text(0.9873750693480946, -0.48486129194837324, 'Юг')])
|
||||||
|
pylab.show()
|
||||||
|
pylab.hist(X1)
|
||||||
|
(array([1., 1., 0., 1., 0., 0., 1., 0., 0., 1.]), array([ 6. , 6.6, 7.2, 7.8, 8.4, 9. , 9.6, 10.2, 10.8, 11.4, 12. ]), <BarContainer object of 10 artists>)
|
||||||
|
pylab.show()
|
||||||
|
pylab.hist(X1, 4)
|
||||||
|
(array([2., 1., 1., 1.]), array([ 6. , 7.5, 9. , 10.5, 12. ]), <BarContainer object of 4 artists>)
|
||||||
|
pylab.show()
|
||||||
|
pylab.bar(X1, X2)
|
||||||
|
<BarContainer object of 5 artists>
|
||||||
|
pylab.show()
|
||||||
|
import statistics as st
|
||||||
|
dir(st)
|
||||||
|
['Counter', 'Decimal', 'Fraction', 'LinearRegression', 'NormalDist', 'StatisticsError', '_SQRT2', '__all__', '__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_coerce', '_convert', '_decimal_sqrt_of_frac', '_exact_ratio', '_fail_neg', '_float_sqrt_of_frac', '_integer_sqrt_of_frac_rto', '_isfinite', '_kernel_invcdfs', '_mean_stdev', '_newton_raphson', '_normal_dist_inv_cdf', '_quartic_invcdf', '_quartic_invcdf_estimate', '_random', '_rank', '_sqrt_bit_width', '_sqrtprod', '_ss', '_sum', '_triweight_invcdf', '_triweight_invcdf_estimate', 'acos', 'asin', 'atan', 'bisect_left', 'bisect_right', 'correlation', 'cos', 'cosh', 'count', 'covariance', 'defaultdict', 'erf', 'exp', 'fabs', 'fmean', 'fsum', 'geometric_mean', 'groupby', 'harmonic_mean', 'hypot', 'isfinite', 'isinf', 'itemgetter', 'kde', 'kde_random', 'linear_regression', 'log', 'math', 'mean', 'median', 'median_grouped', 'median_high', 'median_low', 'mode', 'multimode', 'namedtuple', 'numbers', 'pi', 'pstdev', 'pvariance', 'quantiles', 'random', 'reduce', 'repeat', 'sin', 'sqrt', 'stdev', 'sumprod', 'sys', 'tan', 'tau', 'variance']
|
||||||
|
st.mean(X1)
|
||||||
|
8.6
|
||||||
|
st.median(X2)
|
||||||
|
9
|
||||||
|
st.linear_regression(X1, X2)
|
||||||
|
LinearRegression(slope=-0.5172413793103449, intercept=13.448275862068964)
|
||||||
|
divmod((round(cmath.phase(0.2+0,8j), 2))*20, 3)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#105>", line 1, in <module>
|
||||||
|
divmod((round(cmath.phase(0.2+0,8j), 2))*20, 3)
|
||||||
|
TypeError: cmath.phase() takes exactly one argument (2 given)
|
||||||
|
divmod((round(cmath.phase(0.2+0.8j), 2))*20, 3)
|
||||||
|
(8.0, 2.6000000000000014)
|
||||||
|
round(cmath.phase(0.2+0.8j), 2)
|
||||||
|
1.33
|
||||||
|
(round(cmath.phase(0.2+0.8j), 2))*20
|
||||||
|
26.6
|
||||||
|
divmod((round(cmath.phase(0.2+0.8j), 2))*20, 3)
|
||||||
|
(8.0, 2.6000000000000014)
|
||||||
|
divmod(((round(cmath.phase(0.2+0.8j), 2))*20), 3)
|
||||||
|
(8.0, 2.6000000000000014)
|
||||||
|
tt = time.localtime()
|
||||||
|
tt.tm_hour + ':' + tt.tm_min
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#112>", line 1, in <module>
|
||||||
|
tt.tm_hour + ':' + tt.tm_min
|
||||||
|
TypeError: unsupported operand type(s) for +: 'int' and 'str'
|
||||||
|
str(tt.tm_hour) + ':' + str(tt.tm_min)
|
||||||
|
'2:34'
|
||||||
|
dni = ['Понедельник','Вторник','Среда','Пятница','Четверг','Суббота','Воскресенье']
|
||||||
|
random.sample(dni, 3)
|
||||||
|
['Суббота', 'Пятница', 'Понедельник']
|
||||||
|
random.choice(range(14, 32, 3))
|
||||||
|
26
|
||||||
|
random.sample(['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'], round(random.gauss(15,4)))
|
||||||
|
['s', 'b', 'h', 'j', 'm', 'p', 'i', 'd', 'x', 'r', 'y']
|
||||||
|
(time.time() - time.mktime(tt))/60
|
||||||
|
14.89702452023824
|
||||||
281
TEMA4/report.md
Обычный файл
@@ -0,0 +1,281 @@
|
|||||||
|
# Отчет по теме 4
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку.
|
||||||
|
|
||||||
|
## 2 Стандартные функции из модуля builtins.
|
||||||
|
|
||||||
|
## 2.1 Функция округления
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>help(round)
|
||||||
|
Help on built-in function round in module builtins:
|
||||||
|
|
||||||
|
round(number, ndigits=None)
|
||||||
|
Round a number to a given precision in decimal digits.
|
||||||
|
|
||||||
|
The return value is an integer if ndigits is omitted or None. Otherwise
|
||||||
|
the return value has the same type as the number. ndigits may be negative.
|
||||||
|
>>>round(123.456,1)
|
||||||
|
123.5
|
||||||
|
>>>round(123.456,0)
|
||||||
|
123.0
|
||||||
|
>>>round(123.456)
|
||||||
|
123
|
||||||
|
```
|
||||||
|
В первых двух случаях тип float, во втором - int.
|
||||||
|
|
||||||
|
## 2.2 Функция создания последовательности
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>gg=range(76, 123, 9)
|
||||||
|
>>>type(gg)
|
||||||
|
<class 'range'>
|
||||||
|
>>>list(gg)
|
||||||
|
[76, 85, 94, 103, 112, 121]
|
||||||
|
>>>range(23) # последовательность целых чисел от 0 до 22 включительно с шагом 1
|
||||||
|
range(0, 23)
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.3 Функция zip
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>qq = ['Мамакин','Савин','Симанков','Киреев']
|
||||||
|
>>>ff=zip(gg,qq)
|
||||||
|
>>>tuple(ff)
|
||||||
|
((76, 'Мамакин'), (85, 'Савин'), (94, 'Симанков'), (103, 'Киреев'))
|
||||||
|
>>>ff[1]
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#15>", line 1, in <module>
|
||||||
|
ff[1]
|
||||||
|
TypeError: 'zip' object is not subscriptable
|
||||||
|
```
|
||||||
|
К объекту zip с указанием индекса обращаться нельзя.
|
||||||
|
|
||||||
|
## 2.4 Функция eval
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>fff=float(input('коэффициент усиления='))
|
||||||
|
коэффициент усиления=54
|
||||||
|
>>>dan=eval('5*fff-156')
|
||||||
|
>>>dan
|
||||||
|
114.0
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.5 Функция exec
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>exec(input('введите инструкции:'))
|
||||||
|
введите инструкции:perem=-123.456;gg=round(abs(perem)+98,3)
|
||||||
|
>>>gg
|
||||||
|
221.456
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.6 Другие встроенные функции
|
||||||
|
|
||||||
|
```py
|
||||||
|
list(map(len, qq))
|
||||||
|
[7, 5, 8, 6] # Длины фамилий из списка qq
|
||||||
|
divmod(64,5)
|
||||||
|
(12, 4) # Кортеж с частным и остатком при делении 64 на 5
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Модуль math
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>import math
|
||||||
|
>>>dir(math)
|
||||||
|
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atan2', 'atanh', 'cbrt', 'ceil', 'comb', 'copysign', 'cos', 'cosh', 'degrees', 'dist', 'e', 'erf', 'erfc', 'exp', 'exp2', 'expm1', 'fabs', 'factorial', 'floor', 'fma', 'fmod', 'frexp', 'fsum', 'gamma', 'gcd', 'hypot', 'inf', 'isclose', 'isfinite', 'isinf', 'isnan', 'isqrt', 'lcm', 'ldexp', 'lgamma', 'log', 'log10', 'log1p', 'log2', 'modf', 'nan', 'nextafter', 'perm', 'pi', 'pow', 'prod', 'radians', 'remainder', 'sin', 'sinh', 'sqrt', 'sumprod', 'tan', 'tanh', 'tau', 'trunc', 'ulp']
|
||||||
|
>>>help(math.factorial)
|
||||||
|
Help on built-in function factorial in module math:
|
||||||
|
|
||||||
|
factorial(n, /)
|
||||||
|
Find n!.
|
||||||
|
|
||||||
|
>>>math.factorial(5)
|
||||||
|
120
|
||||||
|
>>>math.degrees(math.acos(math.sin(math.pi)))
|
||||||
|
90.0
|
||||||
|
>>>math.sin(2*math.pi / 7 + math.exp(0.23))
|
||||||
|
0.8334902641414562
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Модуль cmath
|
||||||
|
|
||||||
|
```py
|
||||||
|
import cmath
|
||||||
|
dir(cmath)
|
||||||
|
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atanh', 'cos', 'cosh', 'e', 'exp', 'inf', 'infj', 'isclose', 'isfinite', 'isinf', 'isnan', 'log', 'log10', 'nan', 'nanj', 'phase', 'pi', 'polar', 'rect', 'sin', 'sinh', 'sqrt', 'tan', 'tanh', 'tau']
|
||||||
|
cmath.sqrt(1.2-0.5j)
|
||||||
|
(1.118033988749895-0.22360679774997896j)
|
||||||
|
cmath.phase(1-0.5j)
|
||||||
|
-0.4636476090008061
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5 Модуль random
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>import random
|
||||||
|
>>>dir(random)
|
||||||
|
['BPF', 'LOG4', 'NV_MAGICCONST', 'RECIP_BPF', 'Random', 'SG_MAGICCONST', 'SystemRandom', 'TWOPI', '_ONE', '_Sequence', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_accumulate', '_acos', '_bisect', '_ceil', '_cos', '_e', '_exp', '_fabs', '_floor', '_index', '_inst', '_isfinite', '_lgamma', '_log', '_log2', '_os', '_parse_args', '_pi', '_random', '_repeat', '_sha512', '_sin', '_sqrt', '_test', '_test_generator', '_urandom', 'betavariate', 'binomialvariate', 'choice', 'choices', 'expovariate', 'gammavariate', 'gauss', 'getrandbits', 'getstate', 'lognormvariate', 'main', 'normalvariate', 'paretovariate', 'randbytes', 'randint', 'random', 'randrange', 'sample', 'seed', 'setstate', 'shuffle', 'triangular', 'uniform', 'vonmisesvariate', 'weibullvariate']
|
||||||
|
>>>help(random.seed())
|
||||||
|
Help on NoneType object:
|
||||||
|
|
||||||
|
class NoneType(object)
|
||||||
|
| The type of the None singleton.
|
||||||
|
|
|
||||||
|
| Methods defined here:
|
||||||
|
|
|
||||||
|
| __bool__(self, /)
|
||||||
|
| True if self else False
|
||||||
|
|
|
||||||
|
| __eq__(self, value, /)
|
||||||
|
| Return self==value.
|
||||||
|
|
|
||||||
|
| __ge__(self, value, /)
|
||||||
|
| Return self>=value.
|
||||||
|
|
|
||||||
|
| __gt__(self, value, /)
|
||||||
|
| Return self>value.
|
||||||
|
|
|
||||||
|
| __hash__(self, /)
|
||||||
|
| Return hash(self).
|
||||||
|
|
|
||||||
|
| __le__(self, value, /)
|
||||||
|
| Return self<=value.
|
||||||
|
|
|
||||||
|
| __lt__(self, value, /)
|
||||||
|
| Return self<value.
|
||||||
|
|
|
||||||
|
| __ne__(self, value, /)
|
||||||
|
| Return self!=value.
|
||||||
|
|
|
||||||
|
| __repr__(self, /)
|
||||||
|
| Return repr(self).
|
||||||
|
|
|
||||||
|
| ----------------------------------------------------------------------
|
||||||
|
| Static methods defined here:
|
||||||
|
|
|
||||||
|
| __new__(*args, **kwargs)
|
||||||
|
| Create and return a new object. See help(type) for accurate signature.
|
||||||
|
|
||||||
|
>>>random.seed()
|
||||||
|
>>>random.random()
|
||||||
|
0.6216104315561441
|
||||||
|
>>>random.uniform(0,1)
|
||||||
|
0.15558476742451
|
||||||
|
>>>random.randint(0,100)
|
||||||
|
65
|
||||||
|
>>>random.gauss()
|
||||||
|
-1.2490453714301064
|
||||||
|
>>>random.choice([1,2,3,4,5])
|
||||||
|
5
|
||||||
|
>>>sp = [1,2,3,4,5,6,7,8,9]
|
||||||
|
>>>random.shuffle(sp)
|
||||||
|
>>>sp
|
||||||
|
[8, 2, 5, 9, 6, 7, 1, 3, 4]
|
||||||
|
>>>random.sample(sp, 3)
|
||||||
|
[6, 1, 7]
|
||||||
|
>>>random.betavariate(0.5, 0.5)
|
||||||
|
0.21196520335129634
|
||||||
|
>>>random.gammavariate(0.5, 0.5)
|
||||||
|
0.18678325471924362
|
||||||
|
>>>sp1 = [random.random(), random.gauss(), random.betavariate(0.5,0.5), random.gammavariate(0.5, 0.5)]
|
||||||
|
>>>sp1
|
||||||
|
[0.09352103273802048, 0.41529631729753796, 0.5372987697985309, 0.08540638796369146]
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Модуль time
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>import time
|
||||||
|
>>>dir(time)
|
||||||
|
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'monotonic_ns', 'perf_counter', 'perf_counter_ns', 'process_time', 'process_time_ns', 'sleep', 'strftime', 'strptime', 'struct_time', 'thread_time', 'thread_time_ns', 'time', 'time_ns', 'timezone', 'tzname']
|
||||||
|
>>>c1=time.time()
|
||||||
|
>>>c2=time.time()-c1
|
||||||
|
>>>c2
|
||||||
|
13.89244294166565
|
||||||
|
>>>dat = time.gmtime()
|
||||||
|
>>>dat.tm_mon
|
||||||
|
9
|
||||||
|
>>>dat1 = time.localtime()
|
||||||
|
>>>dat1.tm_mday
|
||||||
|
28
|
||||||
|
>>>time.asctime(dat)
|
||||||
|
'Sat Sep 27 21:23:38 2025'
|
||||||
|
>>>time.ctime(564783)
|
||||||
|
'Wed Jan 7 15:53:03 1970'
|
||||||
|
>>>time.mktime(dat1)
|
||||||
|
1759008378.0
|
||||||
|
>>>time.localtime(c1)
|
||||||
|
time.struct_time(tm_year=2025, tm_mon=9, tm_mday=28, tm_hour=0, tm_min=22, tm_sec=49, tm_wday=6, tm_yday=271, tm_isdst=0)
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7 Модуль pylab
|
||||||
|
|
||||||
|
```py
|
||||||
|
import pylab
|
||||||
|
x=list(range(-3,55,4))
|
||||||
|
t=list(range(15))
|
||||||
|
pylab.plot(t,x)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE16E6850>]
|
||||||
|
pylab.title('Первый график')
|
||||||
|
Text(0.5, 1.0, 'Первый график')
|
||||||
|
pylab.xlabel('время')
|
||||||
|
Text(0.5, 0, 'время')
|
||||||
|
pylab.ylabel('сигнал')
|
||||||
|
Text(0, 0.5, 'сигнал')
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
```py
|
||||||
|
X1=[12,6,8,10,7]
|
||||||
|
X2=[5,7,9,11,13]
|
||||||
|
pylab.plot(X1)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE37DB110>]
|
||||||
|
pylab.plot(X2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000020CE37DB250>]
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
```py
|
||||||
|
region=['Центр','Урал','Сибирь','Юг']
|
||||||
|
naselen=[65,12,23,17]
|
||||||
|
pylab.pie(naselen,labels=region)
|
||||||
|
([<matplotlib.patches.Wedge object at 0x0000020CE16C9940>, <matplotlib.patches.Wedge object at 0x0000020CE1EBCB90>, <matplotlib.patches.Wedge object at 0x0000020CE1EBCF50>, <matplotlib.patches.Wedge object at 0x0000020CE1EBD1D0>], [Text(-0.191013134139045, 1.0832885038559115, 'Центр'), Text(-0.861328292412156, -0.6841882582231001, 'Урал'), Text(0.04429273995539947, -1.0991078896938387, 'Сибирь'), Text(0.9873750693480946, -0.48486129194837324, 'Юг')])
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
```py
|
||||||
|
pylab.hist(X1, 4)
|
||||||
|
(array([2., 1., 1., 1.]), array([ 6. , 7.5, 9. , 10.5, 12. ]), <BarContainer object of 4 artists>)
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
```py
|
||||||
|
pylab.bar(X1, X2)
|
||||||
|
<BarContainer object of 5 artists>
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
## 8 Модуль statistics
|
||||||
|
|
||||||
|
```py
|
||||||
|
import statistics as st
|
||||||
|
dir(st)
|
||||||
|
['Counter', 'Decimal', 'Fraction', 'LinearRegression', 'NormalDist', 'StatisticsError', '_SQRT2', '__all__', '__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_coerce', '_convert', '_decimal_sqrt_of_frac', '_exact_ratio', '_fail_neg', '_float_sqrt_of_frac', '_integer_sqrt_of_frac_rto', '_isfinite', '_kernel_invcdfs', '_mean_stdev', '_newton_raphson', '_normal_dist_inv_cdf', '_quartic_invcdf', '_quartic_invcdf_estimate', '_random', '_rank', '_sqrt_bit_width', '_sqrtprod', '_ss', '_sum', '_triweight_invcdf', '_triweight_invcdf_estimate', 'acos', 'asin', 'atan', 'bisect_left', 'bisect_right', 'correlation', 'cos', 'cosh', 'count', 'covariance', 'defaultdict', 'erf', 'exp', 'fabs', 'fmean', 'fsum', 'geometric_mean', 'groupby', 'harmonic_mean', 'hypot', 'isfinite', 'isinf', 'itemgetter', 'kde', 'kde_random', 'linear_regression', 'log', 'math', 'mean', 'median', 'median_grouped', 'median_high', 'median_low', 'mode', 'multimode', 'namedtuple', 'numbers', 'pi', 'pstdev', 'pvariance', 'quantiles', 'random', 'reduce', 'repeat', 'sin', 'sqrt', 'stdev', 'sumprod', 'sys', 'tan', 'tau', 'variance']
|
||||||
|
st.mean(X1) # вычисление среднего
|
||||||
|
8.6
|
||||||
|
st.median(X2) # вычисление медианы
|
||||||
|
9
|
||||||
|
st.linear_regression(X1, X2) # построение простой линейной регрессионной модели
|
||||||
|
LinearRegression(slope=-0.5172413793103449, intercept=13.448275862068964)
|
||||||
|
```
|
||||||
32
TEMA4/task.md
Обычный файл
@@ -0,0 +1,32 @@
|
|||||||
|
# Общее контрольное задание по теме 4
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Реализовать, записать в текстовый файл и проанализировать результаты последовательности ин-струкций, выполняющих следующие действия:
|
||||||
|
• Напишите и исполните единое выражение, реализующее последовательное выполнение следу-ющих операций: вычисление фазы комплексного числа 0.2+0.8j, округление результата до двух знаков после запятой, умножение полученного значения на 20, получение кортежа из двух зна-чений: округленное вниз значение от деления результата на 3 и остатка от этого деления.
|
||||||
|
• Создайте объект класса struct_time с временными параметрами для текущего московского времени. Создайте строку с текущим часом и минутами.
|
||||||
|
• Создайте список с элементами – названиями дней недели. Сделайте случайную выборку из это-го списка с тремя днями недели.
|
||||||
|
• Напишите инструкцию случайного выбора числа из последовательности целых чисел от 14 до 32 с шагом 3.
|
||||||
|
• Сгенерируйте нормально распределенное число N с математическим ожиданием 15 и стандарт-ным отклонением 4 и округлите его до целого значения. Создайте список с N элементами – случайно выбранными буквами латинского алфавита.
|
||||||
|
• Напишите инструкцию для определения временного интервала в минутах, прошедшего с мо-мента предыдущего (из п.2) определения временных параметров.
|
||||||
|
|
||||||
|
# Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
divmod(((round(cmath.phase(0.2+0.8j), 2))*20), 3)
|
||||||
|
(8.0, 2.6000000000000014)
|
||||||
|
tt = time.localtime()
|
||||||
|
str(tt.tm_hour) + ':' + str(tt.tm_min)
|
||||||
|
'2:34'
|
||||||
|
dni = ['Понедельник','Вторник','Среда','Пятница','Четверг','Суббота','Воскресенье']
|
||||||
|
random.sample(dni, 3)
|
||||||
|
['Суббота', 'Пятница', 'Понедельник']
|
||||||
|
random.choice(range(14, 32, 3))
|
||||||
|
26
|
||||||
|
random.sample(['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'], round(random.gauss(15,4)))
|
||||||
|
['s', 'b', 'h', 'j', 'm', 'p', 'i', 'd', 'x', 'r', 'y']
|
||||||
|
(time.time() - time.mktime(tt))/60
|
||||||
|
14.89702452023824
|
||||||
|
```
|
||||||
Двоичные данные
TEMA5/Figure_1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 37 KiB |
Двоичные данные
TEMA5/Figure_2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 16 KiB |
235
TEMA5/protocol.py
Обычный файл
@@ -0,0 +1,235 @@
|
|||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA5')
|
||||||
|
porog = 10
|
||||||
|
rashod1 = 5
|
||||||
|
rashod2 = 3
|
||||||
|
if rashod1>=porog:
|
||||||
|
dohod=12
|
||||||
|
elif rashod2==porog:
|
||||||
|
dohod=0
|
||||||
|
else:
|
||||||
|
dohod=-8
|
||||||
|
|
||||||
|
dohod
|
||||||
|
-8
|
||||||
|
if rashod1>=3 and rashod2==4:
|
||||||
|
dohod=rashod1
|
||||||
|
if rashod2==porog or rashod1<rashod2:
|
||||||
|
dohod=porog
|
||||||
|
|
||||||
|
dohod
|
||||||
|
-8
|
||||||
|
if porog==3:
|
||||||
|
dohod=1
|
||||||
|
elif porog==4:
|
||||||
|
dohod=2
|
||||||
|
elif porog==5:
|
||||||
|
dohod=3
|
||||||
|
else:
|
||||||
|
dohod=0
|
||||||
|
|
||||||
|
dohod
|
||||||
|
0
|
||||||
|
dohod=2 if porog >= 4 else 0
|
||||||
|
dohod
|
||||||
|
2
|
||||||
|
if porog>=5: rashod1=6;rashod2=0
|
||||||
|
rashod1;rashod2
|
||||||
|
SyntaxError: invalid syntax
|
||||||
|
if porog>=5: rashod1=6;rashod2=0
|
||||||
|
|
||||||
|
rashod1;rashod2
|
||||||
|
6
|
||||||
|
0
|
||||||
|
temperatura=5
|
||||||
|
for i in range(3,18,3):
|
||||||
|
temperatura+=1
|
||||||
|
|
||||||
|
|
||||||
|
temperatura
|
||||||
|
10
|
||||||
|
sps=[2,15,14,8]
|
||||||
|
for k in sps:
|
||||||
|
if len(sps)<=10:sps.append(sps[0])
|
||||||
|
else:break
|
||||||
|
|
||||||
|
|
||||||
|
sps
|
||||||
|
[2, 15, 14, 8, 2, 2, 2, 2, 2, 2, 2]
|
||||||
|
sps=[2,15,14,8]
|
||||||
|
for k in sps[:]:
|
||||||
|
if len(sps)<=10:sps.append(sps[0])
|
||||||
|
else:break
|
||||||
|
|
||||||
|
|
||||||
|
sps
|
||||||
|
[2, 15, 14, 8, 2, 2, 2, 2]
|
||||||
|
import random as rn
|
||||||
|
sps5=[]
|
||||||
|
for i in range(10):
|
||||||
|
sps5.append(rn.randint(1,100))
|
||||||
|
ss=sum(sps5)
|
||||||
|
if ss>500: break
|
||||||
|
else:
|
||||||
|
print(ss)
|
||||||
|
|
||||||
|
|
||||||
|
sps5=[]
|
||||||
|
for i in range(10):
|
||||||
|
sps5.append(rn.randint(1,100))
|
||||||
|
ss=sum(sps5)
|
||||||
|
if ss>500: break
|
||||||
|
else:
|
||||||
|
print(ss)
|
||||||
|
|
||||||
|
|
||||||
|
395
|
||||||
|
stroka='Это – автоматизированная система'
|
||||||
|
stroka1=""
|
||||||
|
for ss in stroka:
|
||||||
|
stroka1+=" "+ss
|
||||||
|
|
||||||
|
stroka1
|
||||||
|
' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а'
|
||||||
|
import math
|
||||||
|
sps2=[math.sin(i*math.pi/5+2) for i in range(100)]
|
||||||
|
import pylab
|
||||||
|
pylab.pl
|
||||||
|
pylab.plot(sps2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000001F9DE202490>]
|
||||||
|
py
|
||||||
|
pylab.show()
|
||||||
|
rashod=300
|
||||||
|
while rashod:
|
||||||
|
print("Расход=",rashod)
|
||||||
|
rashod-=50
|
||||||
|
|
||||||
|
Расход= 300
|
||||||
|
Расход= 250
|
||||||
|
Расход= 200
|
||||||
|
Расход= 150
|
||||||
|
Расход= 100
|
||||||
|
Расход= 50
|
||||||
|
import math
|
||||||
|
stroka='Расчет процесса в объекте регулирования'
|
||||||
|
i=0
|
||||||
|
sps2=[]
|
||||||
|
while i<len(stroka):
|
||||||
|
r=1-2/(1+math.exp(0.1*i))
|
||||||
|
sps2.append(r)
|
||||||
|
print('Значение в момент',i,"=",r)
|
||||||
|
i+=1
|
||||||
|
|
||||||
|
Значение в момент 0 = 0.0
|
||||||
|
Значение в момент 1 = 0.049958374957880025
|
||||||
|
Значение в момент 2 = 0.09966799462495568
|
||||||
|
Значение в момент 3 = 0.14888503362331795
|
||||||
|
Значение в момент 4 = 0.197375320224904
|
||||||
|
Значение в момент 5 = 0.2449186624037092
|
||||||
|
Значение в момент 6 = 0.2913126124515909
|
||||||
|
Значение в момент 7 = 0.3363755443363322
|
||||||
|
Значение в момент 8 = 0.3799489622552249
|
||||||
|
Значение в момент 9 = 0.421899005250008
|
||||||
|
Значение в момент 10 = 0.4621171572600098
|
||||||
|
Значение в момент 11 = 0.5005202111902354
|
||||||
|
Значение в момент 12 = 0.5370495669980353
|
||||||
|
Значение в момент 13 = 0.5716699660851172
|
||||||
|
Значение в момент 14 = 0.6043677771171636
|
||||||
|
Значение в момент 15 = 0.6351489523872873
|
||||||
|
Значение в момент 16 = 0.6640367702678489
|
||||||
|
Значение в момент 17 = 0.6910694698329307
|
||||||
|
Значение в момент 18 = 0.7162978701990245
|
||||||
|
Значение в момент 19 = 0.7397830512740043
|
||||||
|
Значение в момент 20 = 0.7615941559557649
|
||||||
|
Значение в момент 21 = 0.7818063576087741
|
||||||
|
Значение в момент 22 = 0.8004990217606297
|
||||||
|
Значение в момент 23 = 0.8177540779702878
|
||||||
|
Значение в момент 24 = 0.8336546070121553
|
||||||
|
Значение в момент 25 = 0.8482836399575129
|
||||||
|
Значение в момент 26 = 0.8617231593133063
|
||||||
|
Значение в момент 27 = 0.874053287886007
|
||||||
|
Значение в момент 28 = 0.8853516482022625
|
||||||
|
Значение в момент 29 = 0.8956928738431645
|
||||||
|
Значение в момент 30 = 0.9051482536448664
|
||||||
|
Значение в момент 31 = 0.9137854901178277
|
||||||
|
Значение в момент 32 = 0.9216685544064713
|
||||||
|
Значение в момент 33 = 0.9288576214547277
|
||||||
|
Значение в момент 34 = 0.935409070603099
|
||||||
|
Значение в момент 35 = 0.9413755384972874
|
||||||
|
Значение в момент 36 = 0.9468060128462683
|
||||||
|
Значение в момент 37 = 0.9517459571646616
|
||||||
|
Значение в момент 38 = 0.9562374581277391
|
||||||
|
pylab.plot(sps2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000001F9E03EB610>]
|
||||||
|
pylab.show()
|
||||||
|
chislo=267
|
||||||
|
kandidat =chislo // 2
|
||||||
|
while kandidat > 1:
|
||||||
|
if chislo%kandidat == 0:
|
||||||
|
print(chislo, ' имеет множитель ', kandidat)
|
||||||
|
break
|
||||||
|
kandidat -= 1
|
||||||
|
else:
|
||||||
|
print(chislo, ' является простым!')
|
||||||
|
|
||||||
|
267 имеет множитель 89
|
||||||
|
for chislo in range(250, 300):
|
||||||
|
kandidat =chislo // 2
|
||||||
|
while kandidat > 1:
|
||||||
|
if chislo%kandidat == 0:
|
||||||
|
print(chislo, ' имеет множитель ', kandidat)
|
||||||
|
break
|
||||||
|
kandidat -= 1
|
||||||
|
else:
|
||||||
|
print(chislo, ' является простым!')
|
||||||
|
|
||||||
|
250 имеет множитель 125
|
||||||
|
251 является простым!
|
||||||
|
252 имеет множитель 126
|
||||||
|
253 имеет множитель 23
|
||||||
|
254 имеет множитель 127
|
||||||
|
255 имеет множитель 85
|
||||||
|
256 имеет множитель 128
|
||||||
|
257 является простым!
|
||||||
|
258 имеет множитель 129
|
||||||
|
259 имеет множитель 37
|
||||||
|
260 имеет множитель 130
|
||||||
|
261 имеет множитель 87
|
||||||
|
262 имеет множитель 131
|
||||||
|
263 является простым!
|
||||||
|
264 имеет множитель 132
|
||||||
|
265 имеет множитель 53
|
||||||
|
266 имеет множитель 133
|
||||||
|
267 имеет множитель 89
|
||||||
|
268 имеет множитель 134
|
||||||
|
269 является простым!
|
||||||
|
270 имеет множитель 135
|
||||||
|
271 является простым!
|
||||||
|
272 имеет множитель 136
|
||||||
|
273 имеет множитель 91
|
||||||
|
274 имеет множитель 137
|
||||||
|
275 имеет множитель 55
|
||||||
|
276 имеет множитель 138
|
||||||
|
277 является простым!
|
||||||
|
278 имеет множитель 139
|
||||||
|
279 имеет множитель 93
|
||||||
|
280 имеет множитель 140
|
||||||
|
281 является простым!
|
||||||
|
282 имеет множитель 141
|
||||||
|
283 является простым!
|
||||||
|
284 имеет множитель 142
|
||||||
|
285 имеет множитель 95
|
||||||
|
286 имеет множитель 143
|
||||||
|
287 имеет множитель 41
|
||||||
|
288 имеет множитель 144
|
||||||
|
289 имеет множитель 17
|
||||||
|
290 имеет множитель 145
|
||||||
|
291 имеет множитель 97
|
||||||
|
292 имеет множитель 146
|
||||||
|
293 является простым!
|
||||||
|
294 имеет множитель 147
|
||||||
|
295 имеет множитель 59
|
||||||
|
296 имеет множитель 148
|
||||||
|
297 имеет множитель 99
|
||||||
|
298 имеет множитель 149
|
||||||
|
299 имеет множитель 23
|
||||||
292
TEMA5/report.md
Обычный файл
@@ -0,0 +1,292 @@
|
|||||||
|
# Отчет по теме 5
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку.
|
||||||
|
|
||||||
|
## 2 Управляющая конструкция if
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>>porog = 10
|
||||||
|
>>>rashod1 = 5
|
||||||
|
>>>rashod2 = 3
|
||||||
|
if rashod1>=porog:
|
||||||
|
dohod=12
|
||||||
|
elif rashod2==porog:
|
||||||
|
dohod=0
|
||||||
|
else:
|
||||||
|
dohod=-8
|
||||||
|
|
||||||
|
>>>dohod
|
||||||
|
-8
|
||||||
|
if rashod1>=3 and rashod2==4:
|
||||||
|
dohod=rashod1
|
||||||
|
if rashod2==porog or rashod1<rashod2:
|
||||||
|
dohod=porog
|
||||||
|
|
||||||
|
>>>dohod
|
||||||
|
-8
|
||||||
|
if porog==3:
|
||||||
|
dohod=1
|
||||||
|
elif porog==4:
|
||||||
|
dohod=2
|
||||||
|
elif porog==5:
|
||||||
|
dohod=3
|
||||||
|
else:
|
||||||
|
dohod=0
|
||||||
|
|
||||||
|
>>>dohod
|
||||||
|
0
|
||||||
|
>>>dohod=2 if porog >= 4 else 0
|
||||||
|
>>>dohod
|
||||||
|
2
|
||||||
|
if porog>=5: rashod1=6;rashod2=0
|
||||||
|
|
||||||
|
>>>rashod1;rashod2
|
||||||
|
6
|
||||||
|
0
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Управляющая конструкция for
|
||||||
|
|
||||||
|
## 3.1 Пример простого цикла
|
||||||
|
|
||||||
|
```py
|
||||||
|
temperatura=5
|
||||||
|
for i in range(3,18,3):
|
||||||
|
temperatura+=1
|
||||||
|
|
||||||
|
|
||||||
|
>>>temperatura
|
||||||
|
10
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.2 Пример более сложного цикла
|
||||||
|
|
||||||
|
```py
|
||||||
|
sps=[2,15,14,8]
|
||||||
|
for k in sps:
|
||||||
|
if len(sps)<=10:sps.append(sps[0])
|
||||||
|
else:break
|
||||||
|
|
||||||
|
|
||||||
|
sps
|
||||||
|
[2, 15, 14, 8, 2, 2, 2, 2, 2, 2, 2]
|
||||||
|
|
||||||
|
sps=[2,15,14,8]
|
||||||
|
for k in sps[:]:
|
||||||
|
if len(sps)<=10:sps.append(sps[0])
|
||||||
|
else:break
|
||||||
|
|
||||||
|
|
||||||
|
sps
|
||||||
|
[2, 15, 14, 8, 2, 2, 2, 2]
|
||||||
|
```
|
||||||
|
В первом случае for перебирает все элементы sps, в том числе и добавленные в ходе выполнения цикла, а во втором - только 4 изначальных элемента.
|
||||||
|
|
||||||
|
## 3.3 Пример создания списка
|
||||||
|
|
||||||
|
```py
|
||||||
|
for i in range(10):
|
||||||
|
sps5.append(rn.randint(1,100))
|
||||||
|
ss=sum(sps5)
|
||||||
|
if ss>500: break
|
||||||
|
else:
|
||||||
|
print(ss)
|
||||||
|
|
||||||
|
|
||||||
|
sps5=[]
|
||||||
|
for i in range(10):
|
||||||
|
sps5.append(rn.randint(1,100))
|
||||||
|
ss=sum(sps5)
|
||||||
|
if ss>500: break
|
||||||
|
else:
|
||||||
|
print(ss)
|
||||||
|
|
||||||
|
|
||||||
|
395
|
||||||
|
```
|
||||||
|
Значение выводится только если сумма случайных чисел не превышает 500, это выполняется не всегда.
|
||||||
|
|
||||||
|
## 3.4 Пример работы со строкой
|
||||||
|
|
||||||
|
```py
|
||||||
|
stroka='Это – автоматизированная система'
|
||||||
|
stroka1=""
|
||||||
|
for ss in stroka:
|
||||||
|
stroka1+=" "+ss
|
||||||
|
|
||||||
|
stroka1
|
||||||
|
' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.5 Запись цикла в одну строку
|
||||||
|
|
||||||
|
```py
|
||||||
|
import math
|
||||||
|
sps2=[math.sin(i*math.pi/5+2) for i in range(100)]
|
||||||
|
import pylab
|
||||||
|
pylab.plot(sps2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000001F9DE202490>]
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 4 Управляющая инструкция while
|
||||||
|
|
||||||
|
## 4.1 Цикл со счетчиком
|
||||||
|
|
||||||
|
```py
|
||||||
|
rashod=300
|
||||||
|
while rashod:
|
||||||
|
print("Расход=",rashod)
|
||||||
|
rashod-=50
|
||||||
|
|
||||||
|
Расход= 300
|
||||||
|
Расход= 250
|
||||||
|
Расход= 200
|
||||||
|
Расход= 150
|
||||||
|
Расход= 100
|
||||||
|
Расход= 50
|
||||||
|
```
|
||||||
|
Когда rashod доходит до 0, соответствующее ему булево значение становится False и цикл завершается.
|
||||||
|
|
||||||
|
## 4.2 Пример со строками
|
||||||
|
|
||||||
|
```py
|
||||||
|
import math
|
||||||
|
stroka='Расчет процесса в объекте регулирования'
|
||||||
|
i=0
|
||||||
|
sps2=[]
|
||||||
|
while i<len(stroka):
|
||||||
|
r=1-2/(1+math.exp(0.1*i))
|
||||||
|
sps2.append(r)
|
||||||
|
print('Значение в момент',i,"=",r)
|
||||||
|
i+=1
|
||||||
|
|
||||||
|
Значение в момент 0 = 0.0
|
||||||
|
Значение в момент 1 = 0.049958374957880025
|
||||||
|
Значение в момент 2 = 0.09966799462495568
|
||||||
|
Значение в момент 3 = 0.14888503362331795
|
||||||
|
Значение в момент 4 = 0.197375320224904
|
||||||
|
Значение в момент 5 = 0.2449186624037092
|
||||||
|
Значение в момент 6 = 0.2913126124515909
|
||||||
|
Значение в момент 7 = 0.3363755443363322
|
||||||
|
Значение в момент 8 = 0.3799489622552249
|
||||||
|
Значение в момент 9 = 0.421899005250008
|
||||||
|
Значение в момент 10 = 0.4621171572600098
|
||||||
|
Значение в момент 11 = 0.5005202111902354
|
||||||
|
Значение в момент 12 = 0.5370495669980353
|
||||||
|
Значение в момент 13 = 0.5716699660851172
|
||||||
|
Значение в момент 14 = 0.6043677771171636
|
||||||
|
Значение в момент 15 = 0.6351489523872873
|
||||||
|
Значение в момент 16 = 0.6640367702678489
|
||||||
|
Значение в момент 17 = 0.6910694698329307
|
||||||
|
Значение в момент 18 = 0.7162978701990245
|
||||||
|
Значение в момент 19 = 0.7397830512740043
|
||||||
|
Значение в момент 20 = 0.7615941559557649
|
||||||
|
Значение в момент 21 = 0.7818063576087741
|
||||||
|
Значение в момент 22 = 0.8004990217606297
|
||||||
|
Значение в момент 23 = 0.8177540779702878
|
||||||
|
Значение в момент 24 = 0.8336546070121553
|
||||||
|
Значение в момент 25 = 0.8482836399575129
|
||||||
|
Значение в момент 26 = 0.8617231593133063
|
||||||
|
Значение в момент 27 = 0.874053287886007
|
||||||
|
Значение в момент 28 = 0.8853516482022625
|
||||||
|
Значение в момент 29 = 0.8956928738431645
|
||||||
|
Значение в момент 30 = 0.9051482536448664
|
||||||
|
Значение в момент 31 = 0.9137854901178277
|
||||||
|
Значение в момент 32 = 0.9216685544064713
|
||||||
|
Значение в момент 33 = 0.9288576214547277
|
||||||
|
Значение в момент 34 = 0.935409070603099
|
||||||
|
Значение в момент 35 = 0.9413755384972874
|
||||||
|
Значение в момент 36 = 0.9468060128462683
|
||||||
|
Значение в момент 37 = 0.9517459571646616
|
||||||
|
Значение в момент 38 = 0.9562374581277391
|
||||||
|
pylab.plot(sps2)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000001F9E03EB610>]
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## 4.3 Пример с выявлением простых чисел
|
||||||
|
|
||||||
|
```py
|
||||||
|
chislo=267
|
||||||
|
kandidat =chislo // 2
|
||||||
|
while kandidat > 1:
|
||||||
|
if chislo%kandidat == 0:
|
||||||
|
print(chislo, ' имеет множитель ', kandidat)
|
||||||
|
break
|
||||||
|
kandidat -= 1
|
||||||
|
else:
|
||||||
|
print(chislo, ' является простым!')
|
||||||
|
|
||||||
|
267 имеет множитель 89
|
||||||
|
|
||||||
|
for chislo in range(250, 300):
|
||||||
|
kandidat =chislo // 2
|
||||||
|
while kandidat > 1:
|
||||||
|
if chislo%kandidat == 0:
|
||||||
|
print(chislo, ' имеет множитель ', kandidat)
|
||||||
|
break
|
||||||
|
kandidat -= 1
|
||||||
|
else:
|
||||||
|
print(chislo, ' является простым!')
|
||||||
|
|
||||||
|
250 имеет множитель 125
|
||||||
|
251 является простым!
|
||||||
|
252 имеет множитель 126
|
||||||
|
253 имеет множитель 23
|
||||||
|
254 имеет множитель 127
|
||||||
|
255 имеет множитель 85
|
||||||
|
256 имеет множитель 128
|
||||||
|
257 является простым!
|
||||||
|
258 имеет множитель 129
|
||||||
|
259 имеет множитель 37
|
||||||
|
260 имеет множитель 130
|
||||||
|
261 имеет множитель 87
|
||||||
|
262 имеет множитель 131
|
||||||
|
263 является простым!
|
||||||
|
264 имеет множитель 132
|
||||||
|
265 имеет множитель 53
|
||||||
|
266 имеет множитель 133
|
||||||
|
267 имеет множитель 89
|
||||||
|
268 имеет множитель 134
|
||||||
|
269 является простым!
|
||||||
|
270 имеет множитель 135
|
||||||
|
271 является простым!
|
||||||
|
272 имеет множитель 136
|
||||||
|
273 имеет множитель 91
|
||||||
|
274 имеет множитель 137
|
||||||
|
275 имеет множитель 55
|
||||||
|
276 имеет множитель 138
|
||||||
|
277 является простым!
|
||||||
|
278 имеет множитель 139
|
||||||
|
279 имеет множитель 93
|
||||||
|
280 имеет множитель 140
|
||||||
|
281 является простым!
|
||||||
|
282 имеет множитель 141
|
||||||
|
283 является простым!
|
||||||
|
284 имеет множитель 142
|
||||||
|
285 имеет множитель 95
|
||||||
|
286 имеет множитель 143
|
||||||
|
287 имеет множитель 41
|
||||||
|
288 имеет множитель 144
|
||||||
|
289 имеет множитель 17
|
||||||
|
290 имеет множитель 145
|
||||||
|
291 имеет множитель 97
|
||||||
|
292 имеет множитель 146
|
||||||
|
293 является простым!
|
||||||
|
294 имеет множитель 147
|
||||||
|
295 имеет множитель 59
|
||||||
|
296 имеет множитель 148
|
||||||
|
297 имеет множитель 99
|
||||||
|
298 имеет множитель 149
|
||||||
|
299 имеет множитель 23
|
||||||
|
```
|
||||||
|
|
||||||
83
TEMA5/task.md
Обычный файл
@@ -0,0 +1,83 @@
|
|||||||
|
# Общее контрольное задание по теме 5
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Реализовать, записать в текстовый файл программы и результаты их выполнения при решении следующих задач:
|
||||||
|
• Для заданной символьной строки с англоязычным текстом (его можно заимствовать из помо-щи) определите порядковый номер каждой буквы в английском алфавите.
|
||||||
|
• Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о нахожде-нии элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с отсутству-ющим словом).
|
||||||
|
• Создайте список студентов вашей группы (3-4 фамилии) и список их средних баллов в летней сессии – в порядке перечисления студентов в первом списке. Создайте еще 2 аналогичных списка для тех же студентов, но в другом порядке, по зимней сессии. Напишите инструкции, позволяющие по указанной (запрошенной и введенной) фамилии студента вывести его средние баллы по двум сессиям.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
st = 'SyntaxError: invalid syntax'
|
||||||
|
alph = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
|
||||||
|
for i in st:
|
||||||
|
if i.lower() in alph:
|
||||||
|
print(i, ' - ', (''.join(alph)).find(i.lower())+1)
|
||||||
|
|
||||||
|
S - 19
|
||||||
|
y - 25
|
||||||
|
n - 14
|
||||||
|
t - 20
|
||||||
|
a - 1
|
||||||
|
x - 24
|
||||||
|
E - 5
|
||||||
|
r - 18
|
||||||
|
r - 18
|
||||||
|
o - 15
|
||||||
|
r - 18
|
||||||
|
i - 9
|
||||||
|
n - 14
|
||||||
|
v - 22
|
||||||
|
a - 1
|
||||||
|
l - 12
|
||||||
|
i - 9
|
||||||
|
d - 4
|
||||||
|
s - 19
|
||||||
|
y - 25
|
||||||
|
n - 14
|
||||||
|
t - 20
|
||||||
|
a - 1
|
||||||
|
x - 24
|
||||||
|
|
||||||
|
spi='Создайте список со словами из задания данного пункта Для этого списка определите есть ли в нем некоторое заданное значение и выведите соответствующее сообщение либо о нахождении элемента либо о его отсутствии в списке проверить как с имеющимся так и с отсутствующим словом'.split()
|
||||||
|
for i in range(len(spi)):
|
||||||
|
if spi[i] == 'есть':
|
||||||
|
print('найдено')
|
||||||
|
found = True
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
if i == len(spi)-1:
|
||||||
|
print('не найдено')
|
||||||
|
|
||||||
|
найдено
|
||||||
|
|
||||||
|
for i in range(len(spi)):
|
||||||
|
if spi[i] == 'Хевисайд':
|
||||||
|
print('найдено')
|
||||||
|
found = True
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
if i == len(spi)-1:
|
||||||
|
print('не найдено')
|
||||||
|
|
||||||
|
не найдено
|
||||||
|
|
||||||
|
stud1 = ['Мамакин','Савин','Володин','Киреев']
|
||||||
|
leto = [4.57, 3.95, 4.15, 4.83]
|
||||||
|
stud2 = ['Мамакин','Володин','Киреев','Савин']
|
||||||
|
zima = [4.67,4.24,5.0,4.11]
|
||||||
|
fam=input('Введите фамилию студента')
|
||||||
|
Введите фамилию студентаМамакин
|
||||||
|
for i in range(len(stud2)):
|
||||||
|
if stud1[i] == fam:
|
||||||
|
print('Средний за летнюю сессию: ', leto[i])
|
||||||
|
if stud2[i] == fam:
|
||||||
|
print('Средний за зимнюю сессию: ', zima[i])
|
||||||
|
|
||||||
|
Средний за летнюю сессию: 4.57
|
||||||
|
Средний за зимнюю сессию: 4.67
|
||||||
|
```
|
||||||
1
TEMA6/Stroka.txt
Обычный файл
@@ -0,0 +1 @@
|
|||||||
|
запись строки в файл
|
||||||
Двоичные данные
TEMA6/bin.mnz
Обычный файл
0
TEMA6/ddd.txt
Обычный файл
281
TEMA6/report.md
Обычный файл
@@ -0,0 +1,281 @@
|
|||||||
|
# Отчет по теме 6
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку
|
||||||
|
|
||||||
|
## 2 Вывод данных на экран дисплея
|
||||||
|
|
||||||
|
## 2.1 Эхо-вывод
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> stroka='Автоматизированная система управления'
|
||||||
|
>>> stroka
|
||||||
|
'Автоматизированная система управления'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.2 Вывод через print
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> fff=234.5;gg='Значение температуры = '
|
||||||
|
>>> print(gg, fff)
|
||||||
|
Значение температуры = 234.5
|
||||||
|
>>> print(gg, fff, sep='/')
|
||||||
|
Значение температуры = /234.5
|
||||||
|
>>> print(gg, fff,sep='/',end='***'); print('____')
|
||||||
|
Значение температуры = /234.5***____
|
||||||
|
>>> print()
|
||||||
|
|
||||||
|
>>> print(""" Здесь может выводиться
|
||||||
|
... большой текст,
|
||||||
|
... занимающий несколько строк""")
|
||||||
|
...
|
||||||
|
Здесь может выводиться
|
||||||
|
большой текст,
|
||||||
|
занимающий несколько строк
|
||||||
|
>>> print("Здесь может выводиться",
|
||||||
|
... "большой текст,",
|
||||||
|
... "занимающий несколько строк")
|
||||||
|
...
|
||||||
|
Здесь может выводиться большой текст, занимающий несколько строк
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.3 Вывод с использованием метода write
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import sys
|
||||||
|
>>> sys.stdout.write('Функция write')
|
||||||
|
Функция write13
|
||||||
|
>>> sys.stdout.write('Функция write\n')
|
||||||
|
Функция write
|
||||||
|
14
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Ввод с клавиатуры через input
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> psw=input('Введите пароль:')
|
||||||
|
Введите пароль:роялб.
|
||||||
|
>>> psw
|
||||||
|
'роялб.'
|
||||||
|
>>> while True:
|
||||||
|
... znach=float(input('Задайте коэф.усиления = '))
|
||||||
|
... if znach<17.5 or znach>23.8:
|
||||||
|
... print('Ошибка!')
|
||||||
|
... else:
|
||||||
|
... break
|
||||||
|
...
|
||||||
|
Задайте коэф.усиления = 15.4
|
||||||
|
Ошибка!
|
||||||
|
Задайте коэф.усиления = 21.6
|
||||||
|
>>> import math
|
||||||
|
>>> print(eval(input('введите выражение для расчета = ')))
|
||||||
|
введите выражение для расчета = math.log10(23/(1+math.exp(-3.24)))
|
||||||
|
1.34504378689765
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Ввод-вывод при работе с файлами
|
||||||
|
|
||||||
|
## 4.1 Функции для работы с путем к файлу
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import os
|
||||||
|
>>> mamakin = os.getcwd()
|
||||||
|
>>> print(mamakin)
|
||||||
|
C:\Users\uprkt\Desktop\ПО\python-labs\TEMA6
|
||||||
|
>>> os.mkdir('Papka')
|
||||||
|
>>> os.listdir()
|
||||||
|
['.gitkeep', 'Papka', 'report.md']
|
||||||
|
>>> os.path.isdir('Papka')
|
||||||
|
True
|
||||||
|
>>> fil=os.path.abspath("report.md")
|
||||||
|
>>> fil
|
||||||
|
'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA6\\report.md'
|
||||||
|
>>> drkt=os.path.dirname(fil)
|
||||||
|
>>> drkt
|
||||||
|
'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA6'
|
||||||
|
>>> os.path.basename(fil)
|
||||||
|
'report.md'
|
||||||
|
>>> os.path.split(fil)
|
||||||
|
('C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA6', 'report.md')
|
||||||
|
>>> os.path.exists(fil)
|
||||||
|
True
|
||||||
|
>>> os.path.exists('C:\\taxes.txt')
|
||||||
|
False
|
||||||
|
>>> os.path.isfile(fil)
|
||||||
|
True
|
||||||
|
>>> os.path.isfile(os.path.dirname(fil)+'fil1.txt')
|
||||||
|
False
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.3 Функция open
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> fp=open(file=drkt+'\\zapis1.txt',mode='w')
|
||||||
|
>>> fp=open(drkt+'\\zapis1.txt','w')
|
||||||
|
>>> fp=open('zapis1.txt','w')
|
||||||
|
>>> type(fp)
|
||||||
|
<class '_io.TextIOWrapper'>
|
||||||
|
>>> dir(fp)
|
||||||
|
['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']
|
||||||
|
>>> fp1=open(drkt+'\\zapis2.bin',mode='wb+')
|
||||||
|
>>> os.path.isfile(drkt+'\\zapis2.bin')
|
||||||
|
True
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.4 Закрытие файла
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> fp.close()
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.5 Запись в файл с помощью write
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> sps=list(range(1,13))
|
||||||
|
>>> fp2=open('zapis3.txt','w')
|
||||||
|
>>> fp2.write(str(sps[:4])+'\n')
|
||||||
|
13
|
||||||
|
>>> fp2.write(str(sps[4:8])+'\n')
|
||||||
|
13
|
||||||
|
>>> fp2.write(str(sps[8:])+'\n')
|
||||||
|
16
|
||||||
|
>>> fp2.close()
|
||||||
|
```
|
||||||
|

|
||||||
|
```py
|
||||||
|
>>> sps3=[['Иванов И.',1],['Петров П.',2],['Сидоров С.',3]]
|
||||||
|
>>> fp3=open('zapis4.txt','w')
|
||||||
|
>>> for i in range(len(sps3)):
|
||||||
|
... stroka4=sps3[i][0]+' '+str(sps3[i][1])
|
||||||
|
... fp3.write(stroka4)
|
||||||
|
...
|
||||||
|
...
|
||||||
|
11
|
||||||
|
11
|
||||||
|
12
|
||||||
|
>>> fp3.close()
|
||||||
|
```
|
||||||
|

|
||||||
|
```py
|
||||||
|
>>> gh=open('zapis5.txt','w')
|
||||||
|
>>> for r in sps3:
|
||||||
|
... gh.write(r[0]+' '+str(r[1])+'\n')
|
||||||
|
...
|
||||||
|
12
|
||||||
|
12
|
||||||
|
13
|
||||||
|
>>> gh.close()
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
## 4.6 Чтение информации из файла
|
||||||
|
|
||||||
|
```py
|
||||||
|
sps1=[]
|
||||||
|
fp=open('zapis3.txt')
|
||||||
|
for stroka in fp:
|
||||||
|
stroka=stroka.rstrip('\n')
|
||||||
|
stroka=stroka.replace('[','')
|
||||||
|
stroka=stroka.replace(']','')
|
||||||
|
sps1=sps1+stroka.split(',')
|
||||||
|
|
||||||
|
|
||||||
|
fp.close()
|
||||||
|
sps1
|
||||||
|
['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12']
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.7 Чтение из файла с помощью метода read
|
||||||
|
|
||||||
|
```py
|
||||||
|
fp=open('zapis3.txt')
|
||||||
|
stroka1=fp.read(12)
|
||||||
|
stroka2=fp.read()
|
||||||
|
fp.close()
|
||||||
|
stroka1
|
||||||
|
'[1, 2, 3, 4]'
|
||||||
|
stroka2
|
||||||
|
'\n[5, 6, 7, 8]\n[9, 10, 11, 12]\n'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.8 Чтение из файла с помощью readline и readlines
|
||||||
|
|
||||||
|
```py
|
||||||
|
fp=open('zapis5.txt')
|
||||||
|
strok3=fp.readline()
|
||||||
|
strok4=fp.readlines()
|
||||||
|
strok3
|
||||||
|
'Иванов И. 1\n'
|
||||||
|
strok4
|
||||||
|
['Петров П. 2\n', 'Сидоров С. 3\n']
|
||||||
|
fp.close()
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.9 Работа с бинарными файлами
|
||||||
|
|
||||||
|
```py
|
||||||
|
import pickle
|
||||||
|
mnoz1={'pen','book','pen','iPhone','table','book'}
|
||||||
|
fp=open('zapis6.mnz','wb')
|
||||||
|
pickle.dump(mnoz1,fp)
|
||||||
|
fp.close()
|
||||||
|
```
|
||||||
|

|
||||||
|
```py
|
||||||
|
>>> fp=open('zapis6.mnz','rb')
|
||||||
|
>>> mnoz2=pickle.load(fp)
|
||||||
|
>>> fp.close()
|
||||||
|
>>> mnoz2
|
||||||
|
{'iPhone', 'pen', 'book', 'table'}
|
||||||
|
>>> mnoz2 is mnoz1
|
||||||
|
False
|
||||||
|
>>> mnoz2 == mnoz1
|
||||||
|
True
|
||||||
|
>>> fp=open('zapis7.2ob','wb')
|
||||||
|
>>> pickle.dump(mnoz1,fp)
|
||||||
|
>>> pickle.dump(sps3,fp)
|
||||||
|
>>> fp.close()
|
||||||
|
>>> fp=open('zapis7.2ob','rb')
|
||||||
|
>>> obj1=pickle.load(fp)
|
||||||
|
>>> obj2=pickle.load(fp)
|
||||||
|
>>> fp.close()
|
||||||
|
>>> obj1
|
||||||
|
{'iPhone', 'pen', 'book', 'table'}
|
||||||
|
>>> obj2
|
||||||
|
[['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]]
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5 Перенаправление потоков
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import sys
|
||||||
|
>>> vr_out=sys.stdout
|
||||||
|
>>> fc=open('Stroka.txt','w')
|
||||||
|
>>> sys.stdout=fc
|
||||||
|
>>> print('запись строки в файл')
|
||||||
|
>>> sys.stdout=vr_out
|
||||||
|
>>> print('запись строки на экран')
|
||||||
|
запись строки на экран
|
||||||
|
>>> fc.close()
|
||||||
|
>>> tmp_in = sys.stdin
|
||||||
|
>>> fd = open("Stroka.txt", "r")
|
||||||
|
>>> sys.stdin = fd
|
||||||
|
>>> sys.stdin
|
||||||
|
<_io.TextIOWrapper name='Stroka.txt' mode='r' encoding='cp1251'>
|
||||||
|
>>> while True:
|
||||||
|
... try:
|
||||||
|
... line = input ()
|
||||||
|
... print(line)
|
||||||
|
... except EOFError:
|
||||||
|
... break
|
||||||
|
...
|
||||||
|
запись строки в файл
|
||||||
|
>>> fd.close()
|
||||||
|
>>> sys.stdin=tmp_in
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
Двоичные данные
TEMA6/ris1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 10 KiB |
Двоичные данные
TEMA6/ris2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 15 KiB |
Двоичные данные
TEMA6/ris3.png
Обычный файл
|
После Ширина: | Высота: | Размер: 14 KiB |
Двоичные данные
TEMA6/ris4.png
Обычный файл
|
После Ширина: | Высота: | Размер: 21 KiB |
Двоичные данные
TEMA6/ris5.png
Обычный файл
|
После Ширина: | Высота: | Размер: 9.7 KiB |
11
TEMA6/spiski.txt
Обычный файл
@@ -0,0 +1,11 @@
|
|||||||
|
-22 -19 -16
|
||||||
|
-10 -7 -4
|
||||||
|
2 5 8
|
||||||
|
14 17 20
|
||||||
|
26 29 32
|
||||||
|
38 41 44
|
||||||
|
50 53 56
|
||||||
|
62 65 68
|
||||||
|
-25 -13 -1
|
||||||
|
11 23 35
|
||||||
|
47 59 71
|
||||||
45
TEMA6/task.md
Обычный файл
@@ -0,0 +1,45 @@
|
|||||||
|
## Общее контрольное задание по теме 6
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Придумайте инструкции и запишите их в файл с расширением .py , которые выполняют следую-щие операции:
|
||||||
|
• Создаётся объект-кортеж со 125 целыми случайными числами из диапазона от 6 до 56, представленными в виде символьных строк.
|
||||||
|
• Создаётся объект-список с вашей фамилией и 4 фамилиями ваших одноклассников.
|
||||||
|
• Записывается кортеж в бинарный файл.
|
||||||
|
• Записывается в этот же файл список и закрывается файл.
|
||||||
|
• Открывается этот файл для чтения и считывает из него данные в 2 новых объекта.
|
||||||
|
• Проверяется на совпадение новых объектов с исходными и выводится соответствующее со-общение.
|
||||||
|
• Разделяется кортеж на совокупности по 5 чисел в каждой и они записываются в виде от-дельных списков со своими именами.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
import random
|
||||||
|
import os
|
||||||
|
import pickle
|
||||||
|
random.seed()
|
||||||
|
kort = tuple([str(random.randint(6, 56)) for i in range(125)])
|
||||||
|
print(kort)
|
||||||
|
fam = ['Мамакин', 'Кузьменко', 'Шабатов', 'Похил', 'Симанков']
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA6')
|
||||||
|
f = open('bin.mnz', 'wb')
|
||||||
|
pickle.dump(kort, f)
|
||||||
|
pickle.dump(fam, f)
|
||||||
|
f.close()
|
||||||
|
f = open('bin.mnz', 'rb')
|
||||||
|
obj1 = pickle.load(f)
|
||||||
|
obj2 = pickle.load(f)
|
||||||
|
if obj1 == kort and obj2 == fam:
|
||||||
|
print('Объекты совпадают')
|
||||||
|
for i in range(0, len(kort), 5):
|
||||||
|
exec(f'spis{i} = kort[i:i+5]')
|
||||||
|
print(spis0)
|
||||||
|
|
||||||
|
= RESTART: C:/Users/uprkt/Desktop/ПО/python-labs/TEMA6/task.py
|
||||||
|
('21', '31', '21', '25', '16', '7', '19', '37', '30', '12', '27', '45', '38', '26', '31', '40', '42', '40', '44', '11', '49', '20', '17', '54', '44', '14', '33', '25', '49', '26', '9', '12', '19', '31', '25', '7', '15', '25', '33', '21', '48', '11', '38', '56', '53', '55', '46', '8', '22', '35', '35', '46', '14', '17', '42', '55', '50', '24', '10', '26', '16', '45', '41', '18', '24', '40', '28', '18', '22', '50', '19', '40', '16', '33', '32', '43', '20', '18', '47', '56', '56', '35', '27', '22', '20', '37', '25', '22', '15', '48', '39', '50', '35', '22', '20', '24', '35', '21', '31', '8', '23', '18', '28', '54', '55', '55', '45', '37', '34', '38', '27', '34', '48', '53', '18', '49', '33', '19', '18', '33', '33', '17', '31', '52', '31')
|
||||||
|
Объекты совпадают
|
||||||
|
('21', '31', '21', '25', '16')
|
||||||
|
```
|
||||||
|
|
||||||
21
TEMA6/task.py
Обычный файл
@@ -0,0 +1,21 @@
|
|||||||
|
import random
|
||||||
|
import os
|
||||||
|
import pickle
|
||||||
|
random.seed()
|
||||||
|
kort = tuple([str(random.randint(6, 56)) for i in range(125)])
|
||||||
|
print(kort)
|
||||||
|
fam = ['Мамакин', 'Кузьменко', 'Шабатов', 'Похил', 'Симанков']
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA6')
|
||||||
|
f = open('bin.mnz', 'wb')
|
||||||
|
pickle.dump(kort, f)
|
||||||
|
pickle.dump(fam, f)
|
||||||
|
f.close()
|
||||||
|
f = open('bin.mnz', 'rb')
|
||||||
|
obj1 = pickle.load(f)
|
||||||
|
obj2 = pickle.load(f)
|
||||||
|
if obj1 == kort and obj2 == fam:
|
||||||
|
print('Объекты совпадают')
|
||||||
|
for i in range(0, len(kort), 5):
|
||||||
|
exec(f'spis{i} = kort[i:i+5]')
|
||||||
|
print(spis0)
|
||||||
|
|
||||||
95
TEMA6/test.md
Обычный файл
@@ -0,0 +1,95 @@
|
|||||||
|
# Тест по модулю 2
|
||||||
|
|
||||||
|
Мамакин Ярослав Романович, вариант 19
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
1) Запросите у пользователя целое число N со значением из диапазона от 10 до 70 (проверить и при необходимости переспросить).
|
||||||
|
|
||||||
|
2) Создайте список SPS1 с N значениями от -25 с шагом 3. Рассчитайте сумму его элементов. Отобразите список и сумму на экране.
|
||||||
|
|
||||||
|
3) Устраните из списка каждый 4-й элемент, переписав их в отдельный список SPS2. Проверьте, что сумма элементов SPS1 и SPS2 равна ранее рассчитанной сумме.
|
||||||
|
|
||||||
|
4) Запросите у пользователя имя текстового файла для вывода результатов.
|
||||||
|
|
||||||
|
5) Запишите в текстовый файл с указанным именем данные из SPS1 по 3 элемента на строке, разделенные пробелом. Затем в этот же файл допишите данные из SPS2 с новой строки также по 3 элемента на строке.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA6')
|
||||||
|
got_n = False
|
||||||
|
while not got_n:
|
||||||
|
n = int(input('Введите целое число от 10 до 70'))
|
||||||
|
if n < 70 and n > 9:
|
||||||
|
got_n = True
|
||||||
|
else:
|
||||||
|
print('Число не лежит в нужном диапазоне')
|
||||||
|
|
||||||
|
Введите целое число от 10 до 703
|
||||||
|
Число не лежит в нужном диапазоне
|
||||||
|
Введите целое число от 10 до 7033
|
||||||
|
sps1 = [i*3 - 25 for i in range(n)]
|
||||||
|
sps1
|
||||||
|
[-25, -22, -19, -16, -13, -10, -7, -4, -1, 2, 5, 8, 11, 14, 17, 20, 23, 26, 29, 32, 35, 38, 41, 44, 47, 50, 53, 56, 59, 62, 65, 68, 71]
|
||||||
|
print(sum(sps1))
|
||||||
|
759
|
||||||
|
sps2 = sps1[::4];sps2
|
||||||
|
[-25, -13, -1, 11, 23, 35, 47, 59, 71]
|
||||||
|
del sps1[::4]
|
||||||
|
print(sum(sps1) + sum(sps2))
|
||||||
|
759
|
||||||
|
filename = input('Введите имя файла для записи')
|
||||||
|
Введите имя файла для записиspiski.txt
|
||||||
|
f = open(filename, 'w')
|
||||||
|
for i in range(len(sps1)):
|
||||||
|
if i % 3 == 2:
|
||||||
|
f.write(str(sps1[i]) + '\n')
|
||||||
|
else:
|
||||||
|
f.write(str(sps1[i]) + ' ')
|
||||||
|
|
||||||
|
4
|
||||||
|
4
|
||||||
|
4
|
||||||
|
4
|
||||||
|
3
|
||||||
|
3
|
||||||
|
2
|
||||||
|
2
|
||||||
|
2
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
>>> for i in range(len(sps2)):
|
||||||
|
... if i % 3 == 2:
|
||||||
|
... f.write(str(sps2[i]) + '\n')
|
||||||
|
... else:
|
||||||
|
... f.write(str(sps2[i]) + ' ')
|
||||||
|
...
|
||||||
|
4
|
||||||
|
4
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
3
|
||||||
|
>>> f.close()
|
||||||
|
```
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
Двоичные данные
TEMA6/testscrn.png
Обычный файл
|
После Ширина: | Высота: | Размер: 18 KiB |
0
TEMA6/zapis1.txt
Обычный файл
0
TEMA6/zapis2.bin
Обычный файл
3
TEMA6/zapis3.txt
Обычный файл
@@ -0,0 +1,3 @@
|
|||||||
|
[1, 2, 3, 4]
|
||||||
|
[5, 6, 7, 8]
|
||||||
|
[9, 10, 11, 12]
|
||||||
1
TEMA6/zapis4.txt
Обычный файл
@@ -0,0 +1 @@
|
|||||||
|
Иванов И. 1Петров П. 2Сидоров С. 3
|
||||||
3
TEMA6/zapis5.txt
Обычный файл
@@ -0,0 +1,3 @@
|
|||||||
|
Иванов И. 1
|
||||||
|
Петров П. 2
|
||||||
|
Сидоров С. 3
|
||||||
Двоичные данные
TEMA6/zapis6.mnz
Обычный файл
Двоичные данные
TEMA6/zapis7.2ob
Обычный файл
Двоичные данные
TEMA7/Figure_1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 18 KiB |
Двоичные данные
TEMA7/Figure_2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 17 KiB |
502
TEMA7/report.md
Обычный файл
@@ -0,0 +1,502 @@
|
|||||||
|
# Отчет по теме 7
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку.
|
||||||
|
|
||||||
|
## 2 Создание пользовательской функции
|
||||||
|
|
||||||
|
## 2.1 Функция без аргументов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def uspeh():
|
||||||
|
... """Подтверждение успеха операции"""
|
||||||
|
... print('Выполнено успешно!')
|
||||||
|
...
|
||||||
|
>>> uspeh()
|
||||||
|
Выполнено успешно!
|
||||||
|
>>> type(uspeh)
|
||||||
|
<class 'function'>
|
||||||
|
>>> dir()
|
||||||
|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'os', 'uspeh']
|
||||||
|
>>> help(uspeh)
|
||||||
|
Help on function uspeh in module __main__:
|
||||||
|
uspeh()
|
||||||
|
Подтверждение успеха операции
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.2 Функция с аргументами
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def sravnenie(a,b):
|
||||||
|
... """Сравнение a и b"""
|
||||||
|
... if a>b:
|
||||||
|
... print(a,'больше',b)
|
||||||
|
... elif a<b:
|
||||||
|
... print(a, 'меньше',b)
|
||||||
|
... else:
|
||||||
|
... print(a, 'равно',b)
|
||||||
|
...
|
||||||
|
>>> n,m=16,5;sravnenie(n,m)
|
||||||
|
x
|
||||||
|
16 больше 5
|
||||||
|
>>> n,m='16','5';sravnenie(n,m)
|
||||||
|
16 меньше 5
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.3 Функция с return
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def logistfun(b,a):
|
||||||
|
... """Вычисление логистической функции"""
|
||||||
|
... import math
|
||||||
|
... return a/(1+math.exp(-b))
|
||||||
|
...
|
||||||
|
...
|
||||||
|
>>> v,w=1,0.7;z=logistfun(w,v)
|
||||||
|
>>> z
|
||||||
|
0.6681877721681662
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.4 Сложение для разных типов аргументов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def slozh(a1,a2,a3,a4):
|
||||||
|
... """Сложение значений четырех аргументов"""
|
||||||
|
... return a1+a2+a3+a4
|
||||||
|
...
|
||||||
|
>>> slozh(1,2,3,4)
|
||||||
|
10
|
||||||
|
>>> slozh('1','2','3','4')
|
||||||
|
'1234'
|
||||||
|
>>> b1=[1,2];b2=[-1,-2];b3=[0,2];b4=[-1,-1]
|
||||||
|
>>> q=slozh(b1,b2,b3,b4)
|
||||||
|
>>> q
|
||||||
|
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||||
|
>>> b1=(1,2);b2=(-1,-2);b3=(0,2);b4=(-1,-1)
|
||||||
|
>>> slozh(b1,b2,b3,b4)
|
||||||
|
(1, 2, -1, -2, 0, 2, -1, -1)
|
||||||
|
>>> b1={'a':1};b2={'b':2};b3={'c':3};b4={'d':4}
|
||||||
|
>>> slozh(b1,b2,b3,b4)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#23>", line 1, in <module>
|
||||||
|
slozh(b1,b2,b3,b4)
|
||||||
|
File "<pyshell#13>", line 3, in slozh
|
||||||
|
return a1+a2+a3+a4
|
||||||
|
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
|
||||||
|
>>> b1={'a',1};b2={'b',2};b3={'c',3};b4={'d',4}
|
||||||
|
>>> slozh(b1,b2,b3,b4)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#25>", line 1, in <module>
|
||||||
|
slozh(b1,b2,b3,b4)
|
||||||
|
File "<pyshell#13>", line 3, in slozh
|
||||||
|
return a1+a2+a3+a4
|
||||||
|
TypeError: unsupported operand type(s) for +: 'set' and 'set'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.5 Модель устройства
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def inerz(x,T,ypred):
|
||||||
|
... """ Модель устройства с памятью:
|
||||||
|
... x- текущее значение вх.сигнала,
|
||||||
|
... T -постоянная времени,
|
||||||
|
... ypred - предыдущее значение выхода устройства"""
|
||||||
|
... y=(x+T\*ypred)/(T+1)
|
||||||
|
... return y
|
||||||
|
...
|
||||||
|
>>> sps=[0]+[1]*100
|
||||||
|
>>> spsy=[]
|
||||||
|
>>> TT=20
|
||||||
|
>>> yy=0
|
||||||
|
>>> for xx in sps:
|
||||||
|
... yy=inerz(xx,TT,yy)
|
||||||
|
... spsy.append(yy)
|
||||||
|
...
|
||||||
|
>>> import matplotlib.pyplot as plt
|
||||||
|
>>> plt.plot(spsy)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000001FD865211D0>]
|
||||||
|
>>> plt.title('Сигнал на выходе устройства')
|
||||||
|
Text(0.5, 1.0, 'Сигнал на выходе устройства')
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
## 3 Функции как объекты
|
||||||
|
|
||||||
|
## 3.1 Список атрибутов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> dir(inerz)
|
||||||
|
\['\_\_annotations\_\_', '\_\_builtins\_\_', '\_\_call\_\_', '\_\_class\_\_', '\_\_closure\_\_', '\_\_code\_\_', '\_\_defaults\_\_', '\_\_delattr\_\_', '\_\_dict\_\_', '\_\_dir\_\_', '\_\_doc\_\_', '\_\_eq\_\_', '\_\_format\_\_', '\_\_ge\_\_', '\_\_get\_\_', '\_\_getattribute\_\_', '\_\_getstate\_\_', '\_\_globals\_\_', '\_\_gt\_\_', '\_\_hash\_\_', '\_\_init\_\_', '\_\_init\_subclass\_\_', '\_\_kwdefaults\_\_', '\_\_le\_\_', '\_\_lt\_\_', '\_\_module\_\_', '\_\_name\_\_', '\_\_ne\_\_', '\_\_new\_\_', '\_\_qualname\_\_', '\_\_reduce\_\_', '\_\_reduce\_ex\_\_', '\_\_repr\_\_', '\_\_setattr\_\_', '\_\_sizeof\_\_', '\_\_str\_\_', '\_\_subclasshook\_\_', '\_\_type\_params\_\_']
|
||||||
|
>>> inerz.__doc__
|
||||||
|
'Модель устройства с памятью:
|
||||||
|
x- текущее значение вх.сигнала,
|
||||||
|
T -постоянная времени,
|
||||||
|
ypred - предыдущее значение выхода устройства'
|
||||||
|
>>> help(inerz)
|
||||||
|
Help on function inerz in module __main__:
|
||||||
|
inerz(x, T, ypred)
|
||||||
|
Модель устройства с памятью:
|
||||||
|
x- текущее значение вх.сигнала,
|
||||||
|
T -постоянная времени,
|
||||||
|
ypred - предыдущее значение выхода устройства
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.2 Сохранение ссылки на объект-функцию в другой переменной
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> fnkt = sravnenie
|
||||||
|
>>> v=16
|
||||||
|
>>> fnkt(v,23)
|
||||||
|
16 меньше 23
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.3 Возможность альтернативного определения функции в программе
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> typ_fun=8
|
||||||
|
>>> if typ_fun==1:
|
||||||
|
... def func():
|
||||||
|
... print('Функция 1')
|
||||||
|
... else:
|
||||||
|
... def func():
|
||||||
|
... print('Функция 2')
|
||||||
|
...
|
||||||
|
>>> func()
|
||||||
|
Функция 2
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Аргументы функции
|
||||||
|
|
||||||
|
## 4.1 Использование функции в качестве аргумента другой функции
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def fun\_arg(fff,a,b,c):
|
||||||
|
... """fff-имя функции, используемой
|
||||||
|
... в качестве аргумента функции fun_arg"""
|
||||||
|
... return a+fff(c,b)
|
||||||
|
...
|
||||||
|
>>> zz=fun_arg(logistfun,-3,1,0.7)
|
||||||
|
>>> zz
|
||||||
|
-2.3318122278318336
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.2 Обязательные и необязательные аргументы
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def logistfun(a,b=1): #Аргумент b – необязательный; значение по умолчанию=1
|
||||||
|
... """Вычисление логистической функции"""
|
||||||
|
... import math
|
||||||
|
... return b/(1+math.exp(-a))
|
||||||
|
...
|
||||||
|
>>> logistfun(0.7)
|
||||||
|
0.6681877721681662
|
||||||
|
>>> logistfun(0.7,2)
|
||||||
|
1.3363755443363323
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.3 Обращение к функции с произвольным (непозиционным) расположением аргументов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> logistfun(b=0.5,a=0.8)
|
||||||
|
0.34498724056380625
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.4 Значения аргументов функции, содержащиеся в списке или кортеже
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> b1=[1,2];b2=[-1,-2];b3=[0,2];b4=[-1,-1]
|
||||||
|
>>> b1234=[b1,b2,b3,b4]
|
||||||
|
>>> qq=slozh(*b1234)
|
||||||
|
>>> qq
|
||||||
|
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.5 Значения аргументов функции, содержащиеся в словаре
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> dic4={"a1":1,"a2":2,"a3":3,"a4":4}
|
||||||
|
>>> qqq=slozh(**dic4)
|
||||||
|
>>> qqq
|
||||||
|
10
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.6 Смешанные ссылки
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> e1=(-1,6);dd2={'a3':3,'a4':9}
|
||||||
|
>>> qqqq=slozh(*e1,**dd2)
|
||||||
|
>>> qqqq
|
||||||
|
17
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.7 Переменное число аргументов у функции
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def func4(*kort7):
|
||||||
|
... """Произвольное число аргументов в составе кортежа"""
|
||||||
|
... smm=0
|
||||||
|
... for elt in kort7:
|
||||||
|
... smm+=elt
|
||||||
|
... return smm
|
||||||
|
...
|
||||||
|
>>> func4(-1,2)
|
||||||
|
1
|
||||||
|
>>> func4(-1,2,0,3,6)
|
||||||
|
10
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.8 Комбинация аргументов
|
||||||
|
|
||||||
|
```py
|
||||||
|
def func4(a,b=7,*kort7): #Аргументы: a-позиционный, b- по умолчанию + кортеж
|
||||||
|
"""Кортеж - сборка аргументов - должен быть последним!"""
|
||||||
|
smm=0
|
||||||
|
for elt in kort7:
|
||||||
|
smm+=elt
|
||||||
|
return a*smm+b
|
||||||
|
|
||||||
|
func4(-1,2,0,3,6)
|
||||||
|
-7
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4.9 Изменение значений объектов, используемых в качестве аргументов функции
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> a=90
|
||||||
|
>>> def func3(b):
|
||||||
|
... b=5*b+67
|
||||||
|
...
|
||||||
|
>>> func3(a)
|
||||||
|
>>> a
|
||||||
|
90
|
||||||
|
>>> sps1=[1,2,3,4]
|
||||||
|
>>> def func2(sps):
|
||||||
|
... sps[1]=99
|
||||||
|
...
|
||||||
|
>>> func2(sps1)
|
||||||
|
>>> print(sps1)
|
||||||
|
[1, 99, 3, 4]
|
||||||
|
>>> kort=(1,2,3,4)
|
||||||
|
>>> func2(kort)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#95>", line 1, in <module>
|
||||||
|
func2(kort)
|
||||||
|
File "<pyshell#91>", line 2, in func2
|
||||||
|
sps\[1]=99
|
||||||
|
TypeError: 'tuple' object does not support item assignment
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5 Специальные типы пользовательских функций
|
||||||
|
|
||||||
|
## 5.1 Анонимные функции
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import math
|
||||||
|
>>> anfun1=lambda: 1.5+math.log10(17.23)
|
||||||
|
>>> anfun1()
|
||||||
|
2.7362852774480286
|
||||||
|
>>> anfun2=lambda a,b : a+math.log10(b)
|
||||||
|
>>> anfun2(17,234)
|
||||||
|
19.369215857410143
|
||||||
|
>>> anfun3=lambda a,b=234: a+math.log10(b)
|
||||||
|
>>> anfun3(100)
|
||||||
|
102.36921585741014
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5.2 Функции-генераторы
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def func5(diap,shag):
|
||||||
|
... """ Итератор, возвращающий значения
|
||||||
|
... из диапазона от 1 до diap с шагом shag"""
|
||||||
|
... for j in range(1,diap+1,shag):
|
||||||
|
... yield j
|
||||||
|
...
|
||||||
|
>>> for mm in func5(7,3):
|
||||||
|
... print(mm)
|
||||||
|
...
|
||||||
|
1
|
||||||
|
4
|
||||||
|
7
|
||||||
|
>>> alp=func5(7,3)
|
||||||
|
>>> print(alp.__next__())
|
||||||
|
1
|
||||||
|
>>> print(alp.__next__())
|
||||||
|
4
|
||||||
|
>>> print(alp.__next__())
|
||||||
|
7
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Локализация объектов в функциях
|
||||||
|
|
||||||
|
## 6.1 Примеры локализации
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> glb = 10
|
||||||
|
>>> def func7(arg):
|
||||||
|
... loc1=15
|
||||||
|
... glb=8
|
||||||
|
... return loc1*arg
|
||||||
|
...
|
||||||
|
>>> res=func7(glb)
|
||||||
|
>>> glb
|
||||||
|
10
|
||||||
|
>>> def func8(arg):
|
||||||
|
... loc1=15
|
||||||
|
... print(glb)
|
||||||
|
... glb=8
|
||||||
|
... return loc1*arg
|
||||||
|
...
|
||||||
|
>>> res=func8(glb)
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#116>", line 1, in <module>
|
||||||
|
res=func8(glb)
|
||||||
|
File "<pyshell#115>", line 3, in func8
|
||||||
|
print(glb)
|
||||||
|
UnboundLocalError: cannot access local variable 'glb' where it is not associated with a value
|
||||||
|
|
||||||
|
# Переменная glb не объявлена внутри функции
|
||||||
|
|
||||||
|
>>> glb=11
|
||||||
|
>>> def func7(arg):
|
||||||
|
... loc1=15
|
||||||
|
... global glb
|
||||||
|
... print(glb)
|
||||||
|
... glb=8
|
||||||
|
... return loc1\*arg
|
||||||
|
...
|
||||||
|
>>> res=func7(glb)
|
||||||
|
11
|
||||||
|
>>> glb
|
||||||
|
8
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6.2 Выявление локализации объекта с помощью функций locals() и globals() из builtins
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> globals().keys()
|
||||||
|
dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\_loader\_\_', '\_\_spec\_\_', '\_\_annotations\_\_', '\_\_builtins\_\_', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ\_fun', 'func', 'fun\_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'func5', 'mm', 'alp', 'glb', 'func7', 'res', 'func8'])
|
||||||
|
>>> locals().keys()
|
||||||
|
dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\_loader\_\_', '\_\_spec\_\_', '\_\_annotations\_\_', '\_\_builtins\_\_', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ\_fun', 'func', 'fun\_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'func5', 'mm', 'alp', 'glb', 'func7', 'res', 'func8'])
|
||||||
|
>>> # Текущая область - глобальная
|
||||||
|
>>> def func8(arg):
|
||||||
|
... loc1=15
|
||||||
|
... glb=8
|
||||||
|
... print(globals().keys()) #Перечень глобальных объектов «изнутри» функции
|
||||||
|
... print(locals().keys()) #Перечень локальных объектов «изнутри» функции
|
||||||
|
... return loc1*arg
|
||||||
|
...
|
||||||
|
>>> hh = func8(glb)
|
||||||
|
dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\_loader\_\_', '\_\_spec\_\_', '\_\_annotations\_\_', '\_\_builtins\_\_', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ\_fun', 'func', 'fun\_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'func5', 'mm', 'alp', 'glb', 'func7', 'res', 'func8'])
|
||||||
|
dict_keys(['arg', 'loc1', 'glb'])
|
||||||
|
>>> # Во втором списке - локальные объекты, использующиеся при работе функции func8
|
||||||
|
>>> 'glb' in globals().keys()
|
||||||
|
True
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6.3 Локализация объектов при использовании вложенных функций
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def func9(arg2,arg3):
|
||||||
|
... def func9_1(arg1):
|
||||||
|
... loc1=15
|
||||||
|
... glb1=8
|
||||||
|
... print('glob_func9_1:',globals().keys())
|
||||||
|
... print('locl_func9_1:',locals().keys())
|
||||||
|
... return loc1*arg1
|
||||||
|
... loc1=5
|
||||||
|
... glb=func9_1(loc1)
|
||||||
|
... print('loc_func9:',locals().keys())
|
||||||
|
... print('glob_func9:',globals().keys())
|
||||||
|
... return arg2+arg3*glb
|
||||||
|
...
|
||||||
|
>>> kk=func9(10,1)
|
||||||
|
glob\_func9\_1: dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\_loader\_\_', '\_\_spec\_\_', '\_\_annotations\_\_', '\_\_builtins\_\_', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ\_fun', 'func', 'fun\_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'func5', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'hh', 'func9'])
|
||||||
|
locl_func9_1: dict_keys(\['arg1', 'loc1', 'glb1'])
|
||||||
|
loc_func9: dict_keys(\['arg2', 'arg3', 'func9_1', 'loc1', 'glb'])
|
||||||
|
glob\_func9: dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\_loader\_\_', '\_\_spec\_\_', '\_\_annotations\_\_', '\_\_builtins\_\_', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ\_fun', 'func', 'fun\_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'func5', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'hh', 'func9'])
|
||||||
|
>>> # Списки глобальных объектов совпадают, локальные объекты доступны только внутри соответствующих функций
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6.4 Пример моделирования системы
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import math
|
||||||
|
>>> znach=input('k1,T,k2,Xm,A,F,N=').split(',')
|
||||||
|
k1,T,k2,Xm,A,F,N=2,10,3,1,5,0.025,30
|
||||||
|
>>> k1=float(znach[0])
|
||||||
|
>>> T=float(znach[1])
|
||||||
|
>>> k2=float(znach[2])
|
||||||
|
>>> Xm=float(znach[3])
|
||||||
|
>>> A=float(znach[4])
|
||||||
|
>>> F=float(znach[5])
|
||||||
|
>>> N=int(znach[6])
|
||||||
|
>>> vhod=[]
|
||||||
|
>>> for i in range(N):
|
||||||
|
... vhod.append(A*math.sin((2*i*math.pi)*F))
|
||||||
|
...
|
||||||
|
>>> vhod
|
||||||
|
[0.0, 0.7821723252011543, 1.545084971874737, 2.2699524986977337, 2.938926261462366, 3.5355339059327378, 4.045084971874737, 4.455032620941839, 4.755282581475767, 4.938441702975689, 5.0, 4.938441702975689, 4.755282581475768, 4.4550326209418385, 4.045084971874737, 3.5355339059327378, 2.9389262614623664, 2.2699524986977324, 1.5450849718747375, 0.7821723252011549, 6.123233995736766e-16, -0.7821723252011559, -1.5450849718747364, -2.2699524986977333, -2.938926261462365, -3.5355339059327386, -4.04508497187474, -4.455032620941839, -4.755282581475767, -4.938441702975688]
|
||||||
|
>>> def realdvig(xtt,kk1,TT,yti1,ytin1):
|
||||||
|
... #Модель реального двигателя
|
||||||
|
... yp=kk1*xtt #усилитель
|
||||||
|
... yti1=yp+yti1 #Интегратор
|
||||||
|
... ytin1=(yti1+TT*ytin1)/(TT+1)
|
||||||
|
... return [yti1,ytin1]
|
||||||
|
...
|
||||||
|
>>> def tahogen(xtt,kk2,yti2):
|
||||||
|
... #Модель тахогенератора
|
||||||
|
... yp=kk2*xtt #усилитель
|
||||||
|
... yti2=yp+yti2 #интегратор
|
||||||
|
... return yti2
|
||||||
|
...
|
||||||
|
...
|
||||||
|
>>> def nechus(xtt,gran):
|
||||||
|
... #зона нечувствит
|
||||||
|
... if xtt<gran and xtt>(-gran):
|
||||||
|
... ytt=0
|
||||||
|
... elif xtt>=gran:
|
||||||
|
... ytt=xtt-gran
|
||||||
|
... elif xtt<=(-gran):
|
||||||
|
... ytt=xtt+gran
|
||||||
|
... return ytt
|
||||||
|
...
|
||||||
|
>>> yi1=0;yin1=0;yi2=0
|
||||||
|
>>> vyhod=[]
|
||||||
|
>>> for xt in vhod:
|
||||||
|
... xt1=xt-yi2 #отрицательная обратная связь
|
||||||
|
... [yi1,yin1]=realdvig(xt1,k1,T,yi1,yin1)
|
||||||
|
... yi2=tahogen(yin1,k2,yi2)
|
||||||
|
... yt=nechus(yin1,Xm)
|
||||||
|
... vyhod.append(yt)
|
||||||
|
...
|
||||||
|
...
|
||||||
|
>>> print('y=',vyhod)
|
||||||
|
y= [0, 0, 0, 0, 0, 0, 0, -1.299465163446989, -1.3579959054305797, 0, 3.7144096317728987, 7.811411673609909, 6.5646766889828605, -1.7207792337901524, -18.81372872718616, -31.38046599103643, -22.278866622819873, 17.097152611947436, 77.81058529582174, 112.97718138176809, 62.60779574768801, -98.35894773519156, -309.62984734263415, -395.51094806311954, -151.2442551724449, 474.0906424325323, 1190.4363664389593, 1337.7521059074418, 237.48484712636358, -2125.064719245332]
|
||||||
|
>>> import matplotlib.pyplot as plt
|
||||||
|
>>> plt.plot(vyhod)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x000002E752D89090>]
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
55
TEMA7/task.md
Обычный файл
@@ -0,0 +1,55 @@
|
|||||||
|
# Общее контрольное задание по теме 7
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Разработайте и проверьте функцию, реализующую для момента времени t расчет выхода y(t) для устройства задержки: на вход поступает сигнал, а на выходе повторяется этот сигнал с за-держкой на заданное время Т.
|
||||||
|
Разработайте и проверьте функцию, реализующую расчет гистограммы по выборке случайной величины с каким-то распределением. Гистограмма при выводе на экран представляется в виде таблицы: границы интервала, число элементов выборки в интервале. Аргументы функции: вы-борка, число интервалов разбиения диапазона изменения случайной величины. Возвращаемый результат функции: список с числами элементов выборки в интервалах разбиения.
|
||||||
|
Разработайте и проверьте анонимную функцию, вычисляющую значение оценки отклика Y ли-нейной регрессии при значении переменной Х
|
||||||
|
Y=b1+b2*X
|
||||||
|
и имеющую аргументы b1, b2 и X.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> def zaderz(vhod, T):
|
||||||
|
... """Функция задержки
|
||||||
|
... Входной сигнал - vhod
|
||||||
|
... Время задержки - T"""
|
||||||
|
... return [0] * T + vhod
|
||||||
|
...
|
||||||
|
>>> x = [1, 2, 4, 8, 16]
|
||||||
|
>>> T = 5
|
||||||
|
>>> zaderz(x, T)
|
||||||
|
[0, 0, 0, 0, 0, 1, 2, 4, 8, 16]
|
||||||
|
|
||||||
|
>>> def histogram(x, n_bins):
|
||||||
|
... low_end = min(x)
|
||||||
|
... high_end = max(x)
|
||||||
|
... bin_w = (high_end - low_end) / n_bins
|
||||||
|
... bins = []
|
||||||
|
... for i in range(n_bins):
|
||||||
|
... lower = low_end + i * bin_w
|
||||||
|
... upper = low_end + (i + 1) * bin_w
|
||||||
|
... bins.append(len(list(filter(lambda j: lower <= j and j < upper, x))))
|
||||||
|
... if i == n_bins - 1:
|
||||||
|
... bins[i] += 1
|
||||||
|
... print(f"Интервал №{i + 1}: Нижняя граница: {lower} Верхняя граница: {upper} Число элементов: {bins[i]}")
|
||||||
|
... return bins
|
||||||
|
...
|
||||||
|
>>> x = [random.uniform(5, 10) for i in range(100)]
|
||||||
|
>>> n_elem = histogram(x, 5)
|
||||||
|
Интервал №1: Нижняя граница: 5.008028779046062 Верхняя граница: 5.9894754634094 Число элементов: 16
|
||||||
|
Интервал №2: Нижняя граница: 5.9894754634094 Верхняя граница: 6.97092214777274 Число элементов: 21
|
||||||
|
Интервал №3: Нижняя граница: 6.97092214777274 Верхняя граница: 7.952368832136078 Число элементов: 19
|
||||||
|
Интервал №4: Нижняя граница: 7.952368832136078 Верхняя граница: 8.933815516499417 Число элементов: 20
|
||||||
|
Интервал №5: Нижняя граница: 8.933815516499417 Верхняя граница: 9.915262200862756 Число элементов: 24
|
||||||
|
>>> print(n_elem)
|
||||||
|
[16, 21, 19, 20, 24]
|
||||||
|
|
||||||
|
>>> regression = lambda x, b1, b2: b1 + b2 * x
|
||||||
|
>>> regression(4, 8, 0.5)
|
||||||
|
10.0
|
||||||
|
```
|
||||||
|
|
||||||
31
TEMA7/test.md
Обычный файл
@@ -0,0 +1,31 @@
|
|||||||
|
# Тест по теме 7
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
28. Разработайте функцию с 3 аргументами: кортеж с числовыми элементами и 2 значения – Т1 и Т2 (T1<T2). функция должна рассчитать и вернуть список с 3 элементами – число элементов списка, меньших Т1, число элементов со значениями между Т1 и Т2, и число элементов, боль-ших Т2.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
def count_n(kort, T1, T2):
|
||||||
|
lower = 0
|
||||||
|
higher = 0
|
||||||
|
inbetween = 0
|
||||||
|
if T1 < T2 and isinstance(kort, tuple):
|
||||||
|
for i in kort:
|
||||||
|
if i < T1:
|
||||||
|
lower += 1
|
||||||
|
elif i >= T1 and i <= T2:
|
||||||
|
inbetween += 1
|
||||||
|
elif i > T2:
|
||||||
|
higher += 1
|
||||||
|
return [lower, inbetween, higher]
|
||||||
|
else:
|
||||||
|
print('Введенные данные не удовлетворяют условию')
|
||||||
|
return []
|
||||||
|
|
||||||
|
print(count_n((1,2,3,4,5,6,7,8), 4, 7))
|
||||||
|
[3, 4, 1]
|
||||||
|
```
|
||||||
2
TEMA8/MM0.py
Обычный файл
@@ -0,0 +1,2 @@
|
|||||||
|
import MM2
|
||||||
|
print('y=',MM2.vyhod)
|
||||||
22
TEMA8/MM1.py
Обычный файл
@@ -0,0 +1,22 @@
|
|||||||
|
def realdvig(xtt,kk1,TT,yti1,ytin1):
|
||||||
|
#Модель реального двигателя
|
||||||
|
yp=kk1*xtt #усилитель
|
||||||
|
yti1=yp+yti1 #Интегратор
|
||||||
|
ytin1=(yti1+TT*ytin1)/(TT+1)
|
||||||
|
return [yti1,ytin1]
|
||||||
|
|
||||||
|
def tahogen(xtt,kk2,yti2):
|
||||||
|
#Модель тахогенератора
|
||||||
|
yp=kk2*xtt #усилитель
|
||||||
|
yti2=yp+yti2 #интегратор
|
||||||
|
return yti2
|
||||||
|
|
||||||
|
def nechus(xtt,gran):
|
||||||
|
#зона нечувствит
|
||||||
|
if xtt<gran and xtt>(-gran):
|
||||||
|
ytt=0
|
||||||
|
elif xtt>=gran:
|
||||||
|
ytt=xtt-gran
|
||||||
|
elif xtt<=(-gran):
|
||||||
|
ytt=xtt+gran
|
||||||
|
return ytt
|
||||||
23
TEMA8/MM2.py
Обычный файл
@@ -0,0 +1,23 @@
|
|||||||
|
znach=input('k1,T,k2,Xm,A,F,N=').split(',')
|
||||||
|
k1=float(znach[0])
|
||||||
|
T=float(znach[1])
|
||||||
|
k2=float(znach[2])
|
||||||
|
Xm=float(znach[3])
|
||||||
|
A=float(znach[4])
|
||||||
|
F=float(znach[5])
|
||||||
|
N=int(znach[6])
|
||||||
|
|
||||||
|
import math
|
||||||
|
vhod=[]
|
||||||
|
for i in range(N):
|
||||||
|
vhod.append(A*math.sin((2*i*math.pi)*F))
|
||||||
|
|
||||||
|
import MM1 as mod
|
||||||
|
yi1=0;yin1=0;yi2=0
|
||||||
|
vyhod=[]
|
||||||
|
for xt in vhod:
|
||||||
|
xt1=xt-yi2 #отрицательная обратная связь
|
||||||
|
[yi1,yin1]=mod.realdvig(xt1,k1,T,yi1,yin1)
|
||||||
|
yi2=mod.tahogen(yin1,k2,yi2)
|
||||||
|
yt=mod.nechus(yin1,Xm)
|
||||||
|
vyhod.append(yt)
|
||||||
6
TEMA8/Mnn.py
Обычный файл
@@ -0,0 +1,6 @@
|
|||||||
|
x = [1, 2, 4, 8, 16]
|
||||||
|
T = 5
|
||||||
|
|
||||||
|
import Moo
|
||||||
|
|
||||||
|
print(Moo.zaderz(x, T))
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
#Модуль Mod0
|
#Модуль Mod0
|
||||||
import Mod1
|
import Mod1
|
||||||
|
Mod1.perm1=1337
|
||||||
print('perm1=',Mod1.perm1)
|
print('perm1=',Mod1.perm1)
|
||||||
from Mod2 import alpha as al
|
from Mod2 import alpha as al
|
||||||
tt=al()
|
tt=al()
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
def alpha():
|
def alpha():
|
||||||
print('****ALPHA****')
|
print('****ALPHA****')
|
||||||
t=input('Значение t=')
|
t=input('Значение t=')
|
||||||
|
print(beta(float(t)))
|
||||||
return t
|
return t
|
||||||
|
|
||||||
|
|
||||||
def beta(q):
|
def beta(q):
|
||||||
print('****BETA****')
|
|
||||||
import math
|
import math
|
||||||
expi=q*math.pi
|
expi=q*math.pi
|
||||||
|
print(alpha())
|
||||||
return math.exp(expi)
|
return math.exp(expi)
|
||||||
|
|
||||||
|
|||||||
3
TEMA8/Moo.py
Обычный файл
@@ -0,0 +1,3 @@
|
|||||||
|
def zaderz(vhod, T):
|
||||||
|
return [0] * T + vhod
|
||||||
|
|
||||||
7
TEMA8/file1.txt
Обычный файл
@@ -0,0 +1,7 @@
|
|||||||
|
1
|
||||||
|
2
|
||||||
|
3
|
||||||
|
4
|
||||||
|
5
|
||||||
|
6
|
||||||
|
8
|
||||||
1
TEMA8/file2.txt
Обычный файл
@@ -0,0 +1 @@
|
|||||||
|
6 7 8 9 10 8 4 6
|
||||||
19
TEMA8/mod_cc.py
Обычный файл
@@ -0,0 +1,19 @@
|
|||||||
|
import math
|
||||||
|
def calculateCorrelation(list1, list2):
|
||||||
|
n = min(len(list1), len(list2))
|
||||||
|
mean1 = sum(list1[:n]) / n
|
||||||
|
mean2 = sum(list2[:n]) / n
|
||||||
|
numerator = 0
|
||||||
|
sum1 = 0
|
||||||
|
sum2 = 0
|
||||||
|
for i in range(n):
|
||||||
|
d1 = list1[i] - mean1
|
||||||
|
d2 = list2[i] - mean2
|
||||||
|
numerator += d1 * d2
|
||||||
|
sum1 += d1 ** 2
|
||||||
|
sum2 += d2 ** 2
|
||||||
|
denominator = math.sqrt(sum1 * sum2)
|
||||||
|
if denominator == 0:
|
||||||
|
print("деление на ноль")
|
||||||
|
return None
|
||||||
|
return numerator / denominator
|
||||||
16
TEMA8/mod_m.py
Обычный файл
@@ -0,0 +1,16 @@
|
|||||||
|
import os, mod_s, mod_cc
|
||||||
|
for i in range(1, 3):
|
||||||
|
while True:
|
||||||
|
filename = os.path.abspath(input(f"Введите имя {i}-го файла: "))
|
||||||
|
if not os.path.isfile(filename):
|
||||||
|
print("Ошибка: введено неверное имя файла")
|
||||||
|
continue
|
||||||
|
newList = mod_s.readList(filename)
|
||||||
|
if not newList:
|
||||||
|
print("Ошибка: в данном файле содержится пустой список значений")
|
||||||
|
continue
|
||||||
|
globals()[f"list{i}"] = newList
|
||||||
|
break
|
||||||
|
correlation = mod_cc.calculateCorrelation(list1, list2)
|
||||||
|
if correlation is not None:
|
||||||
|
print(f"Коэффициент корреляции равен: {correlation}")
|
||||||
7
TEMA8/mod_s.py
Обычный файл
@@ -0,0 +1,7 @@
|
|||||||
|
def readList(filename):
|
||||||
|
numList = []
|
||||||
|
with open(filename, "r") as file:
|
||||||
|
for line in file:
|
||||||
|
for num in line.strip().split():
|
||||||
|
numList.append(float(num))
|
||||||
|
return numList
|
||||||
262
TEMA8/report.md
Обычный файл
@@ -0,0 +1,262 @@
|
|||||||
|
# Отчет по теме 8
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы со средой и подключение необходимых модулей
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import os,sys,importlib
|
||||||
|
>>> os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA8')
|
||||||
|
>>> os.getcwd()
|
||||||
|
'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2 Создание и использование модулей в среде Python.
|
||||||
|
|
||||||
|
## 2.1 Запуск модуля на выполнение путем его импорта.
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import Mod1
|
||||||
|
Mod1:Введите значение = 5
|
||||||
|
Mod1:Значение perm1= 5
|
||||||
|
>>> Mod1.perm1
|
||||||
|
'5'
|
||||||
|
>>> import Mod1
|
||||||
|
>>> importlib.reload(Mod1)
|
||||||
|
Mod1:Введите значение = 3
|
||||||
|
Mod1:Значение perm1= 3
|
||||||
|
<module 'Mod1' from 'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8\\Mod1.py'>
|
||||||
|
>>> Mod1.perm1
|
||||||
|
'3'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.2 Словарь импортированных модулей
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> print(sorted(sys.modules.keys()))
|
||||||
|
\['Mod1', '\_\_future\_\_', '\_\_main\_\_', '\_abc', '\_ast', '\_bisect', '\_bz2', '\_codecs', '\_collections', '\_collections\_abc', '\_colorize', '\_compat\_pickle', '\_compression', '\_datetime', '\_frozen\_importlib', '\_frozen\_importlib\_external', '\_functools', '\_heapq', '\_imp', '\_io', '\_lzma', '\_opcode', '\_opcode\_metadata', '\_operator', '\_pickle', '\_pyrepl', '\_pyrepl.pager', '\_queue', '\_random', '\_signal', '\_sitebuiltins', '\_socket', '\_sre', '\_stat', '\_string', '\_struct', '\_sysconfig', '\_thread', '\_tkinter', '\_tokenize', '\_typing', '\_warnings', '\_weakref', '\_weakrefset', '\_winapi', '\_wmi', 'abc', 'ast', 'bdb', 'binascii', 'bisect', 'builtins', 'bz2', 'codecs', 'collections', 'collections.abc', 'configparser', 'contextlib', 'copyreg', 'datetime', 'dis', 'encodings', 'encodings.aliases', 'encodings.cp1251', 'encodings.utf\_8', 'enum', 'errno', 'fnmatch', 'functools', 'genericpath', 'heapq', 'idlelib', 'idlelib.autocomplete', 'idlelib.autocomplete\_w', 'idlelib.calltip', 'idlelib.calltip\_w', 'idlelib.config', 'idlelib.debugger', 'idlelib.debugger\_r', 'idlelib.debugobj', 'idlelib.debugobj\_r', 'idlelib.hyperparser', 'idlelib.iomenu', 'idlelib.macosx', 'idlelib.multicall', 'idlelib.pyparse', 'idlelib.rpc', 'idlelib.run', 'idlelib.scrolledlist', 'idlelib.stackviewer', 'idlelib.tooltip', 'idlelib.tree', 'idlelib.util', 'idlelib.window', 'idlelib.zoomheight', 'importlib', 'importlib.\_abc', 'importlib.\_bootstrap', 'importlib.\_bootstrap\_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'ipaddress', 'itertools', 'keyword', 'linecache', 'lzma', 'marshal', 'math', 'nt', 'ntpath', 'opcode', 'operator', 'os', 'os.path', 'pickle', 'pkgutil', 'platform', 'plistlib', 'posixpath', 'pydoc', 'pyexpat', 'pyexpat.errors', 'pyexpat.model', 'queue', 'random', 're', 're.\_casefix', 're.\_compiler', 're.\_constants', 're.\_parser', 'reprlib', 'select', 'selectors', 'shlex', 'shutil', 'site', 'socket', 'socketserver', 'stat', 'string', 'struct', 'sys', 'sysconfig', 'tempfile', 'textwrap', 'threading', 'time', 'tkinter', 'tkinter.constants', 'token', 'tokenize', 'traceback', 'types', 'typing', 'urllib', 'urllib.parse', 'warnings', 'weakref', 'winreg', 'xml', 'xml.parsers', 'xml.parsers.expat', 'xml.parsers.expat.errors', 'xml.parsers.expat.model', 'zipimport', 'zlib']
|
||||||
|
>>> sys.modules.pop('Mod1')
|
||||||
|
<module 'Mod1' from 'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8\\Mod1.py'>
|
||||||
|
>>> print(sorted(sys.modules.keys()))
|
||||||
|
\['\_\_future\_\_', '\_\_main\_\_', '\_abc', '\_ast', '\_bisect', '\_bz2', '\_codecs', '\_collections', '\_collections\_abc', '\_colorize', '\_compat\_pickle', '\_compression', '\_datetime', '\_frozen\_importlib', '\_frozen\_importlib\_external', '\_functools', '\_heapq', '\_imp', '\_io', '\_lzma', '\_opcode', '\_opcode\_metadata', '\_operator', '\_pickle', '\_pyrepl', '\_pyrepl.pager', '\_queue', '\_random', '\_signal', '\_sitebuiltins', '\_socket', '\_sre', '\_stat', '\_string', '\_struct', '\_sysconfig', '\_thread', '\_tkinter', '\_tokenize', '\_typing', '\_warnings', '\_weakref', '\_weakrefset', '\_winapi', '\_wmi', 'abc', 'ast', 'bdb', 'binascii', 'bisect', 'builtins', 'bz2', 'codecs', 'collections', 'collections.abc', 'configparser', 'contextlib', 'copyreg', 'datetime', 'dis', 'encodings', 'encodings.aliases', 'encodings.cp1251', 'encodings.utf\_8', 'enum', 'errno', 'fnmatch', 'functools', 'genericpath', 'heapq', 'idlelib', 'idlelib.autocomplete', 'idlelib.autocomplete\_w', 'idlelib.calltip', 'idlelib.calltip\_w', 'idlelib.config', 'idlelib.debugger', 'idlelib.debugger\_r', 'idlelib.debugobj', 'idlelib.debugobj\_r', 'idlelib.hyperparser', 'idlelib.iomenu', 'idlelib.macosx', 'idlelib.multicall', 'idlelib.pyparse', 'idlelib.rpc', 'idlelib.run', 'idlelib.scrolledlist', 'idlelib.stackviewer', 'idlelib.tooltip', 'idlelib.tree', 'idlelib.util', 'idlelib.window', 'idlelib.zoomheight', 'importlib', 'importlib.\_abc', 'importlib.\_bootstrap', 'importlib.\_bootstrap\_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'ipaddress', 'itertools', 'keyword', 'linecache', 'lzma', 'marshal', 'math', 'nt', 'ntpath', 'opcode', 'operator', 'os', 'os.path', 'pickle', 'pkgutil', 'platform', 'plistlib', 'posixpath', 'pydoc', 'pyexpat', 'pyexpat.errors', 'pyexpat.model', 'queue', 'random', 're', 're.\_casefix', 're.\_compiler', 're.\_constants', 're.\_parser', 'reprlib', 'select', 'selectors', 'shlex', 'shutil', 'site', 'socket', 'socketserver', 'stat', 'string', 'struct', 'sys', 'sysconfig', 'tempfile', 'textwrap', 'threading', 'time', 'tkinter', 'tkinter.constants', 'token', 'tokenize', 'traceback', 'types', 'typing', 'urllib', 'urllib.parse', 'warnings', 'weakref', 'winreg', 'xml', 'xml.parsers', 'xml.parsers.expat', 'xml.parsers.expat.errors', 'xml.parsers.expat.model', 'zipimport', 'zlib']
|
||||||
|
import Mod1
|
||||||
|
Mod1:Введите значение = 2
|
||||||
|
Mod1:Значение perm1= 2
|
||||||
|
Mod1.perm1
|
||||||
|
'2'
|
||||||
|
sys.modules.pop('Mod1')
|
||||||
|
<module 'Mod1' from 'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8\\Mod1.py'>
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.3 Запуск модуля на выполнение с помощью функции exec()
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> exec(open('Mod1.py').read())
|
||||||
|
Mod1:Введите значение = 6
|
||||||
|
Mod1:Значение perm1= 6
|
||||||
|
>>> Mod1.perm1
|
||||||
|
'2'
|
||||||
|
>>> perm1
|
||||||
|
'6'
|
||||||
|
>>> exec(open('Mod1.py').read())
|
||||||
|
Mod1:Введите значение = 7
|
||||||
|
Mod1:Значение perm1= 7
|
||||||
|
>>> perm1
|
||||||
|
'7'
|
||||||
|
>>> exec(open('Mod1.py').read())
|
||||||
|
Mod1:Введите значение = 8
|
||||||
|
Mod1:Значение perm1= 8
|
||||||
|
>>> perm1
|
||||||
|
'8'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.4
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> from Mod1 import perm1
|
||||||
|
Mod1:Введите значение = 9
|
||||||
|
Mod1:Значение perm1= 9
|
||||||
|
>>> perm1
|
||||||
|
'9'
|
||||||
|
>>> dir()
|
||||||
|
\['Mod1', '\_\_annotations\_\_', '\_\_builtins\_\_', '\_\_doc\_\_', '\_\_loader\_\_', '\_\_name\_\_', '\_\_package\_\_', '\_\_spec\_\_', '\_\_warningregistry\_\_', 'importlib', 'os', 'perm1', 'sys']
|
||||||
|
>>> from Mod2 import beta
|
||||||
|
>>> g=beta(2)
|
||||||
|
>>> g
|
||||||
|
535.4916555247646
|
||||||
|
>>> dir()
|
||||||
|
\['Mod1', '\_\_annotations\_\_', '\_\_builtins\_\_', '\_\_doc\_\_', '\_\_loader\_\_', '\_\_name\_\_', '\_\_package\_\_', '\_\_spec\_\_', '\_\_warningregistry\_\_', 'beta', 'g', 'importlib', 'os', 'perm1', 'sys']
|
||||||
|
>>> alpha()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#30>", line 1, in <module>
|
||||||
|
alpha()
|
||||||
|
NameError: name 'alpha' is not defined
|
||||||
|
>>> from Mod2 import alpha as al
|
||||||
|
>>> al()
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=5
|
||||||
|
'5'
|
||||||
|
>>> del al,beta
|
||||||
|
>>> from Mod2 import alpha as al, beta as bt
|
||||||
|
>>> del al,bt
|
||||||
|
>>> from Mod2 import *
|
||||||
|
>>> tt=alpha()
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=0.12
|
||||||
|
>>> uu=beta(float(tt))
|
||||||
|
>>> uu
|
||||||
|
1.4578913609506803
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Создание многомодульных программ
|
||||||
|
|
||||||
|
## 3.1 Пример простой многомодульной программы
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> sys.modules.pop('Mod1')
|
||||||
|
<module 'Mod1' from 'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8\\Mod1.py'>
|
||||||
|
>>> sys.modules.pop('Mod2')
|
||||||
|
<module 'Mod2' from 'C:\\Users\\uprkt\\Desktop\\ПО\\python-labs\\TEMA8\\Mod2.py'>
|
||||||
|
>>> import Mod0
|
||||||
|
Mod1:Введите значение = 7
|
||||||
|
Mod1:Значение perm1= 7
|
||||||
|
perm1= 7
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=8
|
||||||
|
tt= 8
|
||||||
|
qq= 82226315585.59491
|
||||||
|
>>> Mod0.tt;Mod0.qq;Mod0.Mod1.perm1
|
||||||
|
'8'
|
||||||
|
82226315585.59491
|
||||||
|
'7'
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.2 Пример 2
|
||||||
|
|
||||||
|
Модуль ММ2:
|
||||||
|
```py
|
||||||
|
znach=input('k1,T,k2,Xm,A,F,N=').split(',')
|
||||||
|
k1=float(znach[0])
|
||||||
|
T=float(znach[1])
|
||||||
|
k2=float(znach[2])
|
||||||
|
Xm=float(znach[3])
|
||||||
|
A=float(znach[4])
|
||||||
|
F=float(znach[5])
|
||||||
|
N=int(znach[6])
|
||||||
|
|
||||||
|
import math
|
||||||
|
vhod=[]
|
||||||
|
for i in range(N):
|
||||||
|
vhod.append(A*math.sin((2*i*math.pi)*F))
|
||||||
|
|
||||||
|
import MM1 as mod
|
||||||
|
yi1=0;yin1=0;yi2=0
|
||||||
|
vyhod=[]
|
||||||
|
for xt in vhod:
|
||||||
|
xt1=xt-yi2 #отрицательная обратная связь
|
||||||
|
[yi1,yin1]=mod.realdvig(xt1,k1,T,yi1,yin1)
|
||||||
|
yi2=mod.tahogen(yin1,k2,yi2)
|
||||||
|
yt=mod.nechus(yin1,Xm)
|
||||||
|
vyhod.append(yt)
|
||||||
|
```
|
||||||
|
|
||||||
|
Модуль MM0:
|
||||||
|
```py
|
||||||
|
import MM2
|
||||||
|
print('y=',MM2.vyhod)
|
||||||
|
```
|
||||||
|
Запустим модуль MM0:
|
||||||
|
```py
|
||||||
|
import MM0
|
||||||
|
k1,T,k2,Xm,A,F,N=2,10,3,1,5,0.025,30
|
||||||
|
y= [0, 0, 0, 0, 0, 0, 0, -1.299465163446989, -1.3579959054305797, 0, 3.7144096317728987, 7.811411673609909, 6.5646766889828605, -1.7207792337901524, -18.81372872718616, -31.38046599103643, -22.278866622819873, 17.097152611947436, 77.81058529582174, 112.97718138176809, 62.60779574768801, -98.35894773519156, -309.62984734263415, -395.51094806311954, -151.2442551724449, 474.0906424325323, 1190.4363664389593, 1337.7521059074418, 237.48484712636358, -2125.064719245332]
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3.3 Области действия объектов в модулях
|
||||||
|
|
||||||
|
```py
|
||||||
|
def alpha():
|
||||||
|
print('****ALPHA****')
|
||||||
|
t=input('Значение t=')
|
||||||
|
beta(float(t))
|
||||||
|
return t
|
||||||
|
|
||||||
|
|
||||||
|
def beta(q):
|
||||||
|
import math
|
||||||
|
expi=q*math.pi
|
||||||
|
alpha()
|
||||||
|
return math.exp(expi)
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> Mod2.alpha()
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=9
|
||||||
|
'9'
|
||||||
|
>>> Mod2.beta(8)
|
||||||
|
82226315585.59491
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
#Модуль Mod0
|
||||||
|
import Mod1
|
||||||
|
print('perm1=',Mod1.perm1)
|
||||||
|
from Mod2 import alpha as al
|
||||||
|
tt=al()
|
||||||
|
print('tt=',tt)
|
||||||
|
from Mod2 import beta
|
||||||
|
qq=beta(float(tt))
|
||||||
|
print('qq=',qq)
|
||||||
|
print('t=',t)
|
||||||
|
print('expi=',expi)
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import Mod0
|
||||||
|
perm1= 9
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=1
|
||||||
|
tt= 1
|
||||||
|
qq= 23.140692632779267
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#12>", line 1, in <module>
|
||||||
|
import Mod0
|
||||||
|
File "C:\Users\uprkt\Desktop\ПО\python-labs\TEMA8\Mod0.py", line 10, in <module>
|
||||||
|
print('t=',t)
|
||||||
|
NameError: name 't' is not defined. Did you mean: 'tt'?
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
#Модуль Mod0
|
||||||
|
import Mod1
|
||||||
|
Mod1.perm1=1337
|
||||||
|
print('perm1=',Mod1.perm1)
|
||||||
|
from Mod2 import alpha as al
|
||||||
|
tt=al()
|
||||||
|
print('tt=',tt)
|
||||||
|
from Mod2 import beta
|
||||||
|
qq=beta(float(tt))
|
||||||
|
print('qq=',qq)
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import Mod0
|
||||||
|
perm1= 1337
|
||||||
|
****ALPHA****
|
||||||
|
Значение t=8
|
||||||
|
tt= 8
|
||||||
|
qq= 82226315585.59491
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> Mod0.Mod1.perm1=4
|
||||||
|
>>> Mod0.Mod1.perm1
|
||||||
|
4
|
||||||
|
>>> Mod0.Mod1.tt=10
|
||||||
|
>>> Mod0.Mod1.qq=93865
|
||||||
|
>>> Mod0.Mod1.tt
|
||||||
|
10
|
||||||
|
>>> Mod0.Mod1.qq
|
||||||
|
93865
|
||||||
|
```
|
||||||
80
TEMA8/task.md
Обычный файл
@@ -0,0 +1,80 @@
|
|||||||
|
# Общее контрольное задание по теме 8
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Общее контрольное задание.
|
||||||
|
Разработайте программу, состоящую из трех модулей:
|
||||||
|
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Получен-ный список должен возвращаться в вызывающую программу.
|
||||||
|
|
||||||
|
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
||||||
|
|
||||||
|
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. За-тем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
Модуль 1
|
||||||
|
```py
|
||||||
|
def readList(filename):
|
||||||
|
numList = []
|
||||||
|
with open(filename, "r") as file:
|
||||||
|
for line in file:
|
||||||
|
for num in line.strip().split():
|
||||||
|
numList.append(float(num))
|
||||||
|
return numList
|
||||||
|
```
|
||||||
|
|
||||||
|
Модуль 2
|
||||||
|
```py
|
||||||
|
import math
|
||||||
|
def calculateCorrelation(list1, list2):
|
||||||
|
n = min(len(list1), len(list2))
|
||||||
|
mean1 = sum(list1[:n]) / n
|
||||||
|
mean2 = sum(list2[:n]) / n
|
||||||
|
numerator = 0
|
||||||
|
sum1 = 0
|
||||||
|
sum2 = 0
|
||||||
|
for i in range(n):
|
||||||
|
d1 = list1[i] - mean1
|
||||||
|
d2 = list2[i] - mean2
|
||||||
|
numerator += d1 * d2
|
||||||
|
sum1 += d1 ** 2
|
||||||
|
sum2 += d2 ** 2
|
||||||
|
denominator = math.sqrt(sum1 * sum2)
|
||||||
|
if denominator == 0:
|
||||||
|
print("деление на ноль")
|
||||||
|
return None
|
||||||
|
return numerator / denominator
|
||||||
|
```
|
||||||
|
|
||||||
|
Модуль 3
|
||||||
|
|
||||||
|
```py
|
||||||
|
import os, mod_s, mod_cc
|
||||||
|
for i in range(1, 3):
|
||||||
|
while True:
|
||||||
|
filename = os.path.abspath(input(f"Введите имя {i}-го файла: "))
|
||||||
|
if not os.path.isfile(filename):
|
||||||
|
print("Ошибка: введено неверное имя файла")
|
||||||
|
continue
|
||||||
|
newList = mod_s.readList(filename)
|
||||||
|
if not newList:
|
||||||
|
print("Ошибка: в данном файле содержится пустой список значений")
|
||||||
|
continue
|
||||||
|
globals()[f"list{i}"] = newList
|
||||||
|
break
|
||||||
|
correlation = mod_cc.calculateCorrelation(list1, list2)
|
||||||
|
if correlation is not None:
|
||||||
|
print(f"Коэффициент корреляции равен: {correlation}")
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import mod_m
|
||||||
|
Введите имя 1-го файла: file1.txt
|
||||||
|
Введите имя 2-го файла: file2.txt
|
||||||
|
Коэффициент корреляции равен: -0.1888141941724601
|
||||||
|
```
|
||||||
|
|
||||||
29
TEMA8/test.md
Обычный файл
@@ -0,0 +1,29 @@
|
|||||||
|
# Индивидуальное задание по теме 8
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
По указанному преподавателем варианту контрольного задания обратитесь к индивидуальному заданию с таким номером в теме 7, разработайте функцию, на ее основе создайте модуль. Создайте второй модуль, в котором должны быть инструкции для ввода/создания исходных данных для проверки работы функции, вызов функции и отображение полученных результатов.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
Модуль Moo
|
||||||
|
```py
|
||||||
|
def zaderz(vhod, T):
|
||||||
|
return [0] * T + vhod
|
||||||
|
```
|
||||||
|
Модуль Mnn
|
||||||
|
```py
|
||||||
|
x = [1, 2, 4, 8, 16]
|
||||||
|
T = 5
|
||||||
|
|
||||||
|
import Moo
|
||||||
|
|
||||||
|
print(Moo.zaderz(x, T))
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import Mnn
|
||||||
|
[0, 0, 0, 0, 0, 1, 2, 4, 8, 16]
|
||||||
|
```
|
||||||
30
TEMA9/EMP.py
Обычный файл
@@ -0,0 +1,30 @@
|
|||||||
|
class Employee:
|
||||||
|
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||||
|
self.fio = fio
|
||||||
|
self.otdel = otdel
|
||||||
|
self.dolzhnost = dolzhnost
|
||||||
|
self.oklad = oklad
|
||||||
|
self.bonus = []
|
||||||
|
|
||||||
|
def give_raise(self, amount):
|
||||||
|
print(f'Оклад повышен на {amount} рублей, новый оклад: {self.oklad + amount}')
|
||||||
|
self.oklad = self.oklad + amount
|
||||||
|
|
||||||
|
def transfer(self, new_otdel):
|
||||||
|
self.otdel = new_otdel
|
||||||
|
|
||||||
|
def position(self, new_position):
|
||||||
|
self.dolzhnost = new_position
|
||||||
|
|
||||||
|
def give_bonus(self, bonus):
|
||||||
|
self.bonus.append(bonus)
|
||||||
|
|
||||||
|
def read_bonus(self):
|
||||||
|
return self.bonus
|
||||||
|
|
||||||
|
def remove_bonus(self):
|
||||||
|
if len(self.bonus) != 0:
|
||||||
|
return self.bonus.pop()
|
||||||
|
return None
|
||||||
|
|
||||||
|
svojstvo = property(read_bonus, give_bonus, remove_bonus)
|
||||||
Двоичные данные
TEMA9/Figure_1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 14 KiB |
Двоичные данные
TEMA9/Figure_2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 16 KiB |
5
TEMA9/M0.py
Обычный файл
@@ -0,0 +1,5 @@
|
|||||||
|
import M2
|
||||||
|
|
||||||
|
print(f'Минимальное и максимальное значения: {M2.min_and_max}')
|
||||||
|
print(f'Список средних: {M2.spis}')
|
||||||
|
|
||||||
23
TEMA9/M1.py
Обычный файл
@@ -0,0 +1,23 @@
|
|||||||
|
def min_max(vibork):
|
||||||
|
minim = 0
|
||||||
|
maxim = 0
|
||||||
|
for i in vibork:
|
||||||
|
if i == min(vibork):
|
||||||
|
minim = i
|
||||||
|
if i == max(vibork):
|
||||||
|
maxim = i
|
||||||
|
return (minim, maxim)
|
||||||
|
|
||||||
|
def avg_bins(vibork, N):
|
||||||
|
sum = 0
|
||||||
|
avg = 0
|
||||||
|
outp = []
|
||||||
|
for i in range(len(vibork)):
|
||||||
|
if i % N == 0:
|
||||||
|
if i != 0:
|
||||||
|
avg = sum / N
|
||||||
|
outp.append(avg)
|
||||||
|
sum = 0
|
||||||
|
sum += vibork[i]
|
||||||
|
outp.append(sum / ((i % N) + 1))
|
||||||
|
return outp
|
||||||
25
TEMA9/M2.py
Обычный файл
@@ -0,0 +1,25 @@
|
|||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA9')
|
||||||
|
|
||||||
|
while True:
|
||||||
|
filename = os.path.abspath(input(f"Введите имя файла: "))
|
||||||
|
if os.path.isfile(filename):
|
||||||
|
break
|
||||||
|
|
||||||
|
import pickle
|
||||||
|
|
||||||
|
fp=open(filename, 'rb')
|
||||||
|
vib=pickle.load(fp)
|
||||||
|
fp.close()
|
||||||
|
|
||||||
|
import M1
|
||||||
|
|
||||||
|
min_and_max = M1.min_max(vib)
|
||||||
|
print(f'Число элементов: {len(vib)}')
|
||||||
|
N = int(input('Введите число N'))
|
||||||
|
spis = M1.avg_bins(vib, N)
|
||||||
|
|
||||||
|
import pylab
|
||||||
|
|
||||||
|
pylab.plot(vib)
|
||||||
|
pylab.show()
|
||||||
10
TEMA9/Mod3.py
Обычный файл
@@ -0,0 +1,10 @@
|
|||||||
|
class Class1: #Объявление класса Class1 в модуле
|
||||||
|
def zad_zn(self,znach): # 1 Метод класса
|
||||||
|
self.data=znach # self - ссылка на экземпляр класса Class1
|
||||||
|
def otobrazh(self): # 2 Метод класса
|
||||||
|
print(self.data)#Отображение данных экземпляра
|
||||||
|
class Class2(Class1): #Class2 - наследник класса Class1
|
||||||
|
def otobrazh(self): # Метод класса Class2
|
||||||
|
print('значение=',self.data)#Отображение данных экземпляра
|
||||||
|
def otobrazh(objekt): #Объявление самостоятельной функции
|
||||||
|
print('значение объекта=',objekt)
|
||||||
22
TEMA9/SAU.py
Обычный файл
@@ -0,0 +1,22 @@
|
|||||||
|
class SAU:
|
||||||
|
def __init__(self,zn_param):
|
||||||
|
self.param=zn_param
|
||||||
|
self.ypr=[0,0]
|
||||||
|
|
||||||
|
def zdn_zn(self,upr):
|
||||||
|
self.x=upr
|
||||||
|
|
||||||
|
def model(self):
|
||||||
|
def inerz(x,T,yy):
|
||||||
|
return (x+T*yy)/(T+1)
|
||||||
|
|
||||||
|
y0=self.x-self.ypr[1]*self.param[3] #Обр.связь с усилителем 2
|
||||||
|
y1=self.param[0]*y0 #Усилитель1
|
||||||
|
y2=inerz(y1,self.param[1],self.ypr[0]) #Инерционное звено1
|
||||||
|
y3=inerz(y2,self.param[2],self.ypr[1]) #Инерционное звено2
|
||||||
|
self.ypr[0]=y2
|
||||||
|
self.ypr[1]=y3
|
||||||
|
|
||||||
|
def otobraz(self):
|
||||||
|
print('y=',self.ypr[1])
|
||||||
|
|
||||||
Двоичные данные
TEMA9/binar1.bin
Обычный файл
Двоичные данные
TEMA9/binar2.bin
Обычный файл
313
TEMA9/report.md
Обычный файл
@@ -0,0 +1,313 @@
|
|||||||
|
# Отчет по теме 9
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## 1 Начало работы
|
||||||
|
|
||||||
|
Запустил среду IDLE, установил рабочую папку
|
||||||
|
|
||||||
|
## 2 Создание классов и их наследников
|
||||||
|
|
||||||
|
## 2.1 Создание автономного класса
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> class Class1: #Объявление класса
|
||||||
|
... def zad_zn(self,znach): #Метод 1 класса1 – задание значения data
|
||||||
|
... self.data=znach # self - ссылка на экземпляр класса
|
||||||
|
... def otobrazh(self): # Метод 2 класса1
|
||||||
|
... print(self.data)#Отображение данных экземпляра класса
|
||||||
|
...
|
||||||
|
>>> z1=Class1()
|
||||||
|
>>> z2=Class1()
|
||||||
|
>>> z1.zad_zn('экз.класса 1')
|
||||||
|
>>> z2.zad_zn(-632.453)
|
||||||
|
>>> z1.otobrazh()
|
||||||
|
экз.класса 1
|
||||||
|
>>> z2.otobrazh()
|
||||||
|
-632.453
|
||||||
|
>>> z1.data='Новое значение атрибута у экз.1'
|
||||||
|
>>> z1.otobrazh()
|
||||||
|
Новое значение атрибута у экз.1
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2.2 Создание класса-наследника
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> class Class2(Class1): #Class2 - наследник класса Class1
|
||||||
|
... def otobrazh(self): # Метод класса Class2 – переопределяет метод родителя
|
||||||
|
... print('значение=',self.data)#Отображение данных экземпляра
|
||||||
|
...
|
||||||
|
>>> z3=Class2()
|
||||||
|
>>> dir(z3)
|
||||||
|
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_zn']
|
||||||
|
>>> z3.zad_zn('Совсем новое')
|
||||||
|
>>> z3.otobrazh()
|
||||||
|
значение= Совсем новое
|
||||||
|
>>> z1.otobrazh()
|
||||||
|
Новое значение атрибута у экз.1
|
||||||
|
>>> del z1,z2,z3
|
||||||
|
```
|
||||||
|
|
||||||
|
## 3 Использование классов, содержащихся в модулях
|
||||||
|
|
||||||
|
Содержимое Mod3
|
||||||
|
```py
|
||||||
|
class Class1: #Объявление класса Class1 в модуле
|
||||||
|
def zad_zn(self,znach): # 1 Метод класса
|
||||||
|
self.data=znach # self - ссылка на экземпляр класса Class1
|
||||||
|
def otobrazh(self): # 2 Метод класса
|
||||||
|
print(self.data)#Отображение данных экземпляра
|
||||||
|
class Class2(Class1): #Class2 - наследник класса Class1
|
||||||
|
def otobrazh(self): # Метод класса Class2
|
||||||
|
print('значение=',self.data)#Отображение данных экземпляра
|
||||||
|
def otobrazh(objekt): #Объявление самостоятельной функции
|
||||||
|
print('значение объекта=',objekt)
|
||||||
|
```
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> from Mod3 import Class1 #Частичный импорт содержимого модуля
|
||||||
|
>>> z4=Class1()
|
||||||
|
>>> z4.otobrazh()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#20>", line 1, in <module>
|
||||||
|
z4.otobrazh()
|
||||||
|
File "C:\Users\uprkt\Desktop\ПО\python-labs\TEMA9\Mod3.py", line 5, in otobrazh
|
||||||
|
print(self.data)#Отображение данных экземпляра
|
||||||
|
AttributeError: 'Class1' object has no attribute 'data'
|
||||||
|
>>> # Параметру data обьекта не было присвоено значение
|
||||||
|
>>> from Mod3 import Class1
|
||||||
|
>>> z4=Class1()
|
||||||
|
>>> z4.data='значение данного data у экз.4'
|
||||||
|
>>> z4.otobrazh()
|
||||||
|
значение данного data у экз.4
|
||||||
|
>>> del z4
|
||||||
|
>>> import Mod3
|
||||||
|
>>> z4=Mod3.Class2()
|
||||||
|
>>> z4.zad_zn('Класс из модуля')
|
||||||
|
>>> z4.otobrazh()
|
||||||
|
значение= Класс из модуля
|
||||||
|
>>> Mod3.otobrazh('Объект')
|
||||||
|
значение объекта= Объект
|
||||||
|
>>> # Вызывается самостоятельная функция из модуля, а не метод класса
|
||||||
|
```
|
||||||
|
|
||||||
|
## 4 Использование специальных методов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> class Class3(Class2): #Наследник класса Class2, а через него – и класса Class1
|
||||||
|
... def __init__(self,znach): #Конструктор-вызывается при создании нового экземпляра класса
|
||||||
|
... self.data=znach
|
||||||
|
... def __add__(self,drug_zn): #Вызывается, когда экземпляр участвует в операции «+»
|
||||||
|
... return Class3(self.data+drug_zn)
|
||||||
|
... def zad_dr_zn(self,povtor): #А это - обычный метод
|
||||||
|
... self.data*=povtor
|
||||||
|
...
|
||||||
|
>>> z5=Class3('abc')
|
||||||
|
>>> z5.otobrazh()
|
||||||
|
значение= abc
|
||||||
|
>>> z6=z5+'def'
|
||||||
|
>>> z6.otobrazh()
|
||||||
|
значение= abcdef
|
||||||
|
>>> z6.zad_dr_zn(3)
|
||||||
|
>>> z6.otobrazh()
|
||||||
|
значение= abcdefabcdefabcdef
|
||||||
|
```
|
||||||
|
|
||||||
|
## 5 Присоединение атрибутов к классу
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> dir(Class3)
|
||||||
|
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||||
|
>>> Class3.fio='Иванов И.И.'
|
||||||
|
>>> dir(Class3)
|
||||||
|
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||||
|
>>> z7=Class3(123)
|
||||||
|
>>> dir(z7)==dir(Class3)
|
||||||
|
False
|
||||||
|
>>> z7.fio
|
||||||
|
'Иванов И.И.'
|
||||||
|
>>> z7.rozden='1987'
|
||||||
|
>>> dir(z7)
|
||||||
|
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'data', 'fio', 'otobrazh', 'rozden', 'zad_dr_zn', 'zad_zn']
|
||||||
|
>>> dir(Class3)
|
||||||
|
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Выявление родительских классов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> Class3.__bases__
|
||||||
|
(<class '__main__.Class2'>,)
|
||||||
|
>>> Class2.__bases__
|
||||||
|
(<class '__main__.Class1'>,)
|
||||||
|
>>> Class1.__bases__
|
||||||
|
(<class 'object'>,)
|
||||||
|
>>> Class3.__mro__
|
||||||
|
(<class '__main__.Class3'>, <class '__main__.Class2'>, <class '__main__.Class1'>, <class 'object'>)
|
||||||
|
>>> ZeroDivisionError.__mro__
|
||||||
|
(<class 'ZeroDivisionError'>, <class 'ArithmeticError'>, <class 'Exception'>, <class 'BaseException'>, <class 'object'>)
|
||||||
|
```
|
||||||
|
|
||||||
|
## 7 Создание свойства класса
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> class Class4:
|
||||||
|
... def __init__(sam,znach):
|
||||||
|
... sam.__prm=znach
|
||||||
|
... def chten(sam):
|
||||||
|
... return sam.__prm
|
||||||
|
... def zapis(sam,znch):
|
||||||
|
... sam.__prm=znch
|
||||||
|
... def stiran(sam):
|
||||||
|
... del sam.__prm
|
||||||
|
... svojstvo=property(chten,zapis,stiran)
|
||||||
|
...
|
||||||
|
>>> exempl=Class4(12)
|
||||||
|
>>> exempl.svojstvo
|
||||||
|
12
|
||||||
|
>>> exempl.svojstvo=45
|
||||||
|
>>> print(exempl.svojstvo)
|
||||||
|
45
|
||||||
|
>>> del exempl.svojstvo
|
||||||
|
>>> exempl.svojstvo
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#61>", line 1, in <module>
|
||||||
|
exempl.svojstvo
|
||||||
|
File "<pyshell#55>", line 5, in chten
|
||||||
|
return sam.__prm
|
||||||
|
AttributeError: 'Class4' object has no attribute '_Class4__prm'
|
||||||
|
>>> # Свойство было удалено
|
||||||
|
```
|
||||||
|
|
||||||
|
## 8 Пример представления в виде класса модели системы автоматического регулирования (САР)
|
||||||
|
|
||||||
|
```py
|
||||||
|
class SAU:
|
||||||
|
def __init__(self,zn_param):
|
||||||
|
self.param=zn_param
|
||||||
|
self.ypr=[0,0]
|
||||||
|
|
||||||
|
def zdn_zn(self,upr):
|
||||||
|
self.x=upr
|
||||||
|
|
||||||
|
def model(self):
|
||||||
|
def inerz(x,T,yy):
|
||||||
|
return (x+T*yy)/(T+1)
|
||||||
|
|
||||||
|
y0=self.x-self.ypr[1]*self.param[3] #Обр.связь с усилителем 2
|
||||||
|
y1=self.param[0]*y0 #Усилитель1
|
||||||
|
y2=inerz(y1,self.param[1],self.ypr[0]) #Инерционное звено1
|
||||||
|
y3=inerz(y2,self.param[2],self.ypr[1]) #Инерционное звено2
|
||||||
|
self.ypr[0]=y2
|
||||||
|
self.ypr[1]=y3
|
||||||
|
|
||||||
|
def otobraz(self):
|
||||||
|
print('y=',self.ypr[1])
|
||||||
|
```
|
||||||
|
|
||||||
|
Проверка работы:
|
||||||
|
```py
|
||||||
|
prm=[2.5,4,1.3,0.8] #Параметры модели: коэф.усиления, 2 пост.времени, обратная связь
|
||||||
|
from SAU import *
|
||||||
|
xx=[0]+[1]*20 #Входной сигнал – «ступенька»
|
||||||
|
SAUe=SAU(prm) # Создаём экземпляр класса
|
||||||
|
yt=[]
|
||||||
|
for xt in xx: # Прохождение входного сигнала
|
||||||
|
SAUe.zdn_zn(xt)
|
||||||
|
... SAUe.model()
|
||||||
|
... SAUe.otobraz()
|
||||||
|
... yt.append(SAUe.ypr[1])
|
||||||
|
...
|
||||||
|
y= 0.0
|
||||||
|
y= 0.2173913043478261
|
||||||
|
y= 0.4763705103969754
|
||||||
|
y= 0.686594887811293
|
||||||
|
y= 0.8199324616478645
|
||||||
|
y= 0.8837201137353929
|
||||||
|
y= 0.8994188484874774
|
||||||
|
y= 0.8892777072047301
|
||||||
|
y= 0.870097963179993
|
||||||
|
y= 0.8518346102696789
|
||||||
|
y= 0.8387499784485772
|
||||||
|
y= 0.8314204114211459
|
||||||
|
y= 0.8286051955249649
|
||||||
|
y= 0.8285656555914835
|
||||||
|
y= 0.8297915186846528
|
||||||
|
y= 0.8312697736438287
|
||||||
|
y= 0.8324765218921963
|
||||||
|
y= 0.8332456979978418
|
||||||
|
y= 0.8336163607592184
|
||||||
|
y= 0.8337101315489143
|
||||||
|
y= 0.833654237067147
|
||||||
|
>>> import pylab
|
||||||
|
>>> pylab.plot(yt)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000028C363DA710>]
|
||||||
|
>>> pylab.show()
|
||||||
|
>>> prm=[5.5,2,6.3,0.9]
|
||||||
|
>>> SAUe=SAU(prm)
|
||||||
|
>>> yt=[]
|
||||||
|
>>> for xt in xx: # Прохождение входного сигнала
|
||||||
|
... SAUe.zdn_zn(xt)
|
||||||
|
... SAUe.model()
|
||||||
|
... SAUe.otobraz()
|
||||||
|
... yt.append(SAUe.ypr[1])
|
||||||
|
...
|
||||||
|
y= 0.0
|
||||||
|
y= 0.2511415525114155
|
||||||
|
y= 0.5785429828402243
|
||||||
|
y= 0.8608684291527201
|
||||||
|
y= 1.0405548889736682
|
||||||
|
y= 1.1123698572088563
|
||||||
|
y= 1.1026104028422206
|
||||||
|
y= 1.0485692602883017
|
||||||
|
y= 0.9837333929415083
|
||||||
|
y= 0.9303020862487426
|
||||||
|
y= 0.8979490324812144
|
||||||
|
y= 0.8865131776531742
|
||||||
|
y= 0.8902188772938274
|
||||||
|
y= 0.9016293565437798
|
||||||
|
y= 0.9143726153161045
|
||||||
|
y= 0.9244204691700071
|
||||||
|
y= 0.9301876457452414
|
||||||
|
y= 0.931925085592902
|
||||||
|
y= 0.9308720026158589
|
||||||
|
y= 0.9284995249411967
|
||||||
|
y= 0.9260125207356777
|
||||||
|
>>> pylab.plot(yt)
|
||||||
|
[<matplotlib.lines.Line2D object at 0x0000028C385FB110>]
|
||||||
|
>>> pylab.show()
|
||||||
|
```
|
||||||
|
|
||||||
|

|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Двоичные данные
TEMA9/t1.png
Обычный файл
|
После Ширина: | Высота: | Размер: 16 KiB |
Двоичные данные
TEMA9/t2.png
Обычный файл
|
После Ширина: | Высота: | Размер: 16 KiB |
70
TEMA9/task.md
Обычный файл
@@ -0,0 +1,70 @@
|
|||||||
|
# Общее контрольное задание по теме 9
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
Создайте и запишите в модуль класс, содержащий следующие компоненты:
|
||||||
|
- конструктор, задающий четырем атрибутам (fio, otdel, dolzhnost, oklad), представляющим фамилии сотрудников, название отделов, названия должностей сотрудников и размеры их окладов, некоторые начальные значения;
|
||||||
|
- метод для обеспечения операции повышения оклада сотрудника на заданное значение;
|
||||||
|
- метод для обеспечения перевода сотрудника из одного отдела в другой;
|
||||||
|
- метод для изменения должности сотрудника;
|
||||||
|
- свойство, содержащее перечень (список) поощрений сотрудника.
|
||||||
|
Создайте 2 экземпляра класса, задайте им некоторые значения атрибутов и свойства. Отобрази-те эти значения. Попробуйте с этими экземплярами операции перевода из отдела в отдел, изме-нения должности и оклада, объявления благодарности.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
Содержимое модуля:
|
||||||
|
|
||||||
|
```py
|
||||||
|
class Employee:
|
||||||
|
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||||
|
self.fio = fio
|
||||||
|
self.otdel = otdel
|
||||||
|
self.dolzhnost = dolzhnost
|
||||||
|
self.oklad = oklad
|
||||||
|
self.bonus = []
|
||||||
|
|
||||||
|
def give_raise(self, amount):
|
||||||
|
print(f'Оклад повышен на {amount} рублей, новый оклад: {self.oklad + amount}')
|
||||||
|
self.oklad = self.oklad + amount
|
||||||
|
|
||||||
|
def transfer(self, new_otdel):
|
||||||
|
self.otdel = new_otdel
|
||||||
|
|
||||||
|
def position(self, new_position):
|
||||||
|
self.dolzhnost = new_position
|
||||||
|
|
||||||
|
def give_bonus(self, bonus):
|
||||||
|
self.bonus.append(bonus)
|
||||||
|
|
||||||
|
def read_bonus(self):
|
||||||
|
return self.bonus
|
||||||
|
|
||||||
|
def remove_bonus(self):
|
||||||
|
if len(self.bonus) != 0:
|
||||||
|
return self.bonus.pop()
|
||||||
|
return None
|
||||||
|
|
||||||
|
svojstvo = property(read_bonus, give_bonus, remove_bonus)
|
||||||
|
```
|
||||||
|
|
||||||
|
Проверка работы:
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import EMP
|
||||||
|
>>> de = EMP.Employee('Дерипаска Олег Владимирович', 'Маркетинг', 'Аналитик', 130000)
|
||||||
|
>>> ya = EMP.Employee('Мамакин Ярослав Романович', 'Производственный', 'Арбузолитейщик', 131000)
|
||||||
|
>>> ya.dolzhnost
|
||||||
|
'Арбузолитейщик'
|
||||||
|
>>> de.svojstvo = 'Премного благодарны'
|
||||||
|
>>> de.svojstvo = 'Вы лучший'
|
||||||
|
>>> de.svojstvo
|
||||||
|
['Премного благодарны', 'Вы лучший']
|
||||||
|
>>> de.transfer('Клининговый')
|
||||||
|
>>> de.otdel
|
||||||
|
'Клининговый'
|
||||||
|
>>> ya.give_raise(70000)
|
||||||
|
Оклад повышен на 70000 рублей, новый оклад: 201000
|
||||||
|
```
|
||||||
|
|
||||||
127
TEMA9/test.md
Обычный файл
@@ -0,0 +1,127 @@
|
|||||||
|
# Тест по модулю 3
|
||||||
|
|
||||||
|
Мамакин Ярослав, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
|
||||||
|
M3_27
|
||||||
|
1) Создайте модуль М1, содержащий 2 функции:
|
||||||
|
|
||||||
|
- функция 1: аргумент - список или кортеж с выборкой; определение по списку или кортежу номеров элементов с наименьшим и наибольшим значениями;
|
||||||
|
|
||||||
|
- функция 2: аргументы - список или кортеж с выборкой и целочисленный параметр N; функция должна разделить выборку на непересекающиеся группы, содержащие по заданному числу N элементов с последовательными индексами (в последней группе число элементов может быть меньше N), и расчет по группам среднего значения их элементов; значения средних возвращаются в вызывающую программу в виде списка;
|
||||||
|
|
||||||
|
2) Создайте еще один модуль М2, в котором должны выполняться следующие операции:
|
||||||
|
|
||||||
|
- запрашивается имя бинарного файла с выборкой, проверяется его наличие и при отсутствии - повторяется запрос;
|
||||||
|
|
||||||
|
- выборка вводится из файла;
|
||||||
|
|
||||||
|
- с помощью функции 1 производится определение номеров наименьшего и наибольшего элементов;
|
||||||
|
|
||||||
|
- отображается число элементов в считанной последовательности и запрашивается у пользователя число элементов N для формирования групп;
|
||||||
|
|
||||||
|
- с помощью функции 2 рассчитывается список со средними значениями по группам ;
|
||||||
|
|
||||||
|
- на графике отображается исходная выборка.
|
||||||
|
|
||||||
|
3) Создайте модуль М0 - главную программу, которая вызывает М2 и отображает результаты расчета на экране.
|
||||||
|
|
||||||
|
4) Проведите расчеты при 2-х разных исходных файлах.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
```py
|
||||||
|
def min_max(vibork):
|
||||||
|
minim = 0
|
||||||
|
maxim = 0
|
||||||
|
for i in vibork:
|
||||||
|
if i == min(vibork):
|
||||||
|
minim = i
|
||||||
|
if i == max(vibork):
|
||||||
|
maxim = i
|
||||||
|
return (minim, maxim)
|
||||||
|
|
||||||
|
def avg_bins(vibork, N):
|
||||||
|
sum = 0
|
||||||
|
avg = 0
|
||||||
|
outp = []
|
||||||
|
for i in range(len(vibork)):
|
||||||
|
if i % N == 0:
|
||||||
|
if i != 0:
|
||||||
|
avg = sum / N
|
||||||
|
outp.append(avg)
|
||||||
|
sum = 0
|
||||||
|
sum += vibork[i]
|
||||||
|
outp.append(sum / ((i % N) + 1))
|
||||||
|
return outp
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
```py
|
||||||
|
import os
|
||||||
|
os.chdir(r'C:\Users\uprkt\Desktop\ПО\python-labs\TEMA9')
|
||||||
|
|
||||||
|
while True:
|
||||||
|
filename = os.path.abspath(input(f"Введите имя файла: "))
|
||||||
|
if os.path.isfile(filename):
|
||||||
|
break
|
||||||
|
|
||||||
|
import pickle
|
||||||
|
|
||||||
|
fp=open(filename, 'rb')
|
||||||
|
vib=pickle.load(fp)
|
||||||
|
fp.close()
|
||||||
|
|
||||||
|
import M1
|
||||||
|
|
||||||
|
min_and_max = M1.min_max(vib)
|
||||||
|
print(f'Число элементов: {len(vib)}')
|
||||||
|
N = int(input('Введите число N'))
|
||||||
|
spis = M1.avg_bins(vib, N)
|
||||||
|
|
||||||
|
import pylab
|
||||||
|
|
||||||
|
pylab.plot(vib)
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
```py
|
||||||
|
import M2
|
||||||
|
|
||||||
|
print(f'Минимальное и максимальное значения: {M2.min_and_max}')
|
||||||
|
print(f'Список средних: {spis}')
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
```py
|
||||||
|
import M0
|
||||||
|
Введите имя файла: binar1.bin
|
||||||
|
Число элементов: 9
|
||||||
|
Введите число N3
|
||||||
|
Минимальное и максимальное значения: (1, 9)
|
||||||
|
Список средних: [2.0, 5.0, 8.0]
|
||||||
|
import M0
|
||||||
|
Введите имя файла: binar2.bin
|
||||||
|
Число элементов: 16
|
||||||
|
Введите число N4
|
||||||
|
Минимальное и максимальное значения: (2, 56)
|
||||||
|
Список средних: [4.5, 11.75, 19.0, 4.25]
|
||||||
|
```
|
||||||
|
|
||||||
|

|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||