форкнуто от main/python-labs
Родитель
a20fa6826b
Сommit
0e0029a430
@ -0,0 +1,22 @@
|
|||||||
|
# M0.py
|
||||||
|
import pickle
|
||||||
|
import pylab
|
||||||
|
import M2
|
||||||
|
|
||||||
|
# Получаем данные (они уже прочитаны в M2)
|
||||||
|
data = M2.original_data
|
||||||
|
|
||||||
|
# График
|
||||||
|
pylab.plot(data, marker='o')
|
||||||
|
pylab.title("Исходные данные")
|
||||||
|
pylab.xlabel("Номер")
|
||||||
|
pylab.ylabel("Значение")
|
||||||
|
pylab.grid(True)
|
||||||
|
pylab.show()
|
||||||
|
|
||||||
|
# Запись в бинарный файл
|
||||||
|
f = open("RES2a.bin", "wb")
|
||||||
|
pickle.dump(data, f)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
print("Исходные данные записаны в RES2a.bin")
|
||||||
@ -0,0 +1,53 @@
|
|||||||
|
# M1.py
|
||||||
|
import os
|
||||||
|
import math
|
||||||
|
|
||||||
|
def func1(filename, KK):
|
||||||
|
numbers = []
|
||||||
|
f = open(filename, 'r')
|
||||||
|
for line in f:
|
||||||
|
parts = line.split()
|
||||||
|
for p in parts:
|
||||||
|
numbers.append(float(p))
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
base, ext = os.path.splitext(filename)
|
||||||
|
f1 = open(base + '1' + ext, 'w')
|
||||||
|
f2 = open(base + '2' + ext, 'w')
|
||||||
|
|
||||||
|
for x in numbers:
|
||||||
|
if x > KK:
|
||||||
|
f1.write(str(x) + '\n')
|
||||||
|
else:
|
||||||
|
f2.write(str(x) + '\n')
|
||||||
|
|
||||||
|
f1.close()
|
||||||
|
f2.close()
|
||||||
|
return numbers
|
||||||
|
|
||||||
|
|
||||||
|
def func2(filename):
|
||||||
|
numbers = []
|
||||||
|
f = open(filename, 'r')
|
||||||
|
for line in f:
|
||||||
|
parts = line.split()
|
||||||
|
for p in parts:
|
||||||
|
numbers.append(float(p))
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
if len(numbers) == 0:
|
||||||
|
return 0, 0, 0, 0, 0 # пустой файл
|
||||||
|
|
||||||
|
n = len(numbers)
|
||||||
|
mean = sum(numbers) / n
|
||||||
|
min_val = min(numbers)
|
||||||
|
max_val = max(numbers)
|
||||||
|
std_dev = math.sqrt(sum((x - mean) ** 2 for x in numbers) / n)
|
||||||
|
|
||||||
|
sorted_nums = sorted(numbers)
|
||||||
|
if n % 2 == 1:
|
||||||
|
median = sorted_nums[n // 2]
|
||||||
|
else:
|
||||||
|
median = (sorted_nums[n // 2 - 1] + sorted_nums[n // 2]) / 2
|
||||||
|
|
||||||
|
return mean, median, min_val, max_val, std_dev
|
||||||
@ -0,0 +1,38 @@
|
|||||||
|
# M2.py
|
||||||
|
import os
|
||||||
|
from M1 import func1, func2
|
||||||
|
|
||||||
|
# Запрос имени файла с проверкой существования
|
||||||
|
filename = input("Введите имя файла с исходными данными: ")
|
||||||
|
while not os.path.isfile(filename):
|
||||||
|
print("Файл не найден.")
|
||||||
|
filename = input("Введите имя файла с исходными данными: ")
|
||||||
|
|
||||||
|
# Запрос порога
|
||||||
|
KK = float(input("Введите пороговое значение KK: "))
|
||||||
|
|
||||||
|
# Вызов func1
|
||||||
|
data = func1(filename, KK)
|
||||||
|
|
||||||
|
# Имена новых файлов
|
||||||
|
base, ext = os.path.splitext(filename)
|
||||||
|
file1 = base + '1' + ext
|
||||||
|
file2 = base + '2' + ext
|
||||||
|
|
||||||
|
# Три вызова func2
|
||||||
|
files = [filename, file1, file2]
|
||||||
|
labels = ["Исходный", "Больше KK", "Не больше KK"]
|
||||||
|
|
||||||
|
print("\nРезультаты статистики:")
|
||||||
|
print("-" * 50)
|
||||||
|
for i in range(3):
|
||||||
|
mean, median, minv, maxv, std = func2(files[i])
|
||||||
|
print(f"\n{labels[i]} файл:")
|
||||||
|
print(f" Среднее: {mean:.4f}")
|
||||||
|
print(f" Медиана: {median:.4f}")
|
||||||
|
print(f" Минимум: {minv:.4f}")
|
||||||
|
print(f" Максимум: {maxv:.4f}")
|
||||||
|
print(f" Ст. откл.: {std:.4f}")
|
||||||
|
|
||||||
|
# Возвращаем исходные данные для M0
|
||||||
|
original_data = data
|
||||||
@ -0,0 +1,11 @@
|
|||||||
|
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)
|
||||||
Двоичный файл не отображается.
|
После Ширина: | Высота: | Размер: 25 KiB |
@ -0,0 +1,21 @@
|
|||||||
|
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])
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
1.2 3.5
|
||||||
|
-2.1 4.8 5.0
|
||||||
|
2.3 1.1 6.7 0.0 3.3
|
||||||
|
7.2 -1.5
|
||||||
@ -0,0 +1,6 @@
|
|||||||
|
3.5
|
||||||
|
4.8
|
||||||
|
5.0
|
||||||
|
6.7
|
||||||
|
3.3
|
||||||
|
7.2
|
||||||
@ -0,0 +1,6 @@
|
|||||||
|
1.2
|
||||||
|
-2.1
|
||||||
|
2.3
|
||||||
|
1.1
|
||||||
|
0.0
|
||||||
|
-1.5
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
10 20 30
|
||||||
|
15.5 -5
|
||||||
|
0 25 35.7 40
|
||||||
|
12.3 18.9
|
||||||
@ -0,0 +1,13 @@
|
|||||||
|
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])
|
||||||
|
import pylab
|
||||||
|
pylab.plot(yt)
|
||||||
|
pylab.show()
|
||||||
@ -0,0 +1,270 @@
|
|||||||
|
# Отчет по теме 9
|
||||||
|
|
||||||
|
Анисенков Павел, А-01-23
|
||||||
|
|
||||||
|
## 1 Запуск интерактивной оболочки IDLE
|
||||||
|
|
||||||
|
Была запущена интерактивная оболочка 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() #Создаём 1-й экземпляр класса
|
||||||
|
>>> z2=Class1() #Создаём 2-й экземпляр класса
|
||||||
|
>>> z1.zad_zn('экз.класса 1') #Обращение к 1 методу класса у 1-го экз.
|
||||||
|
>>> z2.zad_zn(-632.453) #Обращение к 1 методу класса у 2-го экз.
|
||||||
|
>>> z1.otobrazh() # Обращение ко второму методу класса у 1-го экз.
|
||||||
|
экз.класса 1
|
||||||
|
>>> z2.otobrazh() # Обращение ко второму методу класса у 2-го экз.
|
||||||
|
-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() #Метод из Class2 (потому что он переопределяет родительский).
|
||||||
|
значение= Совсем новое
|
||||||
|
>>> z1.otobrazh() # z1 Не изменилось У каждого экземпляра — свой data
|
||||||
|
Новое значение атрибута у экз.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)
|
||||||
|
```
|
||||||
|
|
||||||
|
Далее импортирован класс из этого модуля (при вызове метода otobrazh была выведена ошибка, так как не было задано значение обьекта с помощью метода zad_zn, которое и должно выводиться на печать):
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> from Mod3 import Class1 #Частичный импорт содержимого модуля
|
||||||
|
>>> z4=Class1()
|
||||||
|
>>> z4.otobrazh()
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#19>", line 1, in <module>
|
||||||
|
z4.otobrazh()
|
||||||
|
File "C:\Users\Professional\Desktop\python-labs\TEMA9\Mod3.py", line 5, in otobrazh
|
||||||
|
print(self.data)#Отображение данных экземпляра
|
||||||
|
AttributeError: 'Class1' object has no attribute 'data' #y z4 нет атрибута data
|
||||||
|
```
|
||||||
|
Далее была произведена еще попытка печати, но предварительно было задано знаечние обьекта:
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> from Mod3 import Class1
|
||||||
|
>>> z4=Class1()
|
||||||
|
>>> z4.data='значение данного data у экз.4'
|
||||||
|
>>> z4.otobrazh()
|
||||||
|
значение данного data у экз.4
|
||||||
|
```
|
||||||
|
|
||||||
|
Потом был импортирован весь модуль и из него с использованием разных методов был вызван otobrazh:
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> import Mod3 #Полный импорт содержимого модуля
|
||||||
|
>>> z4=Mod3.Class2()
|
||||||
|
>>> z4.zad_zn('Класс из модуля')
|
||||||
|
>>> z4.otobrazh() #метод класса Class2
|
||||||
|
значение= Класс из модуля
|
||||||
|
>>> 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='Иванов И.И.'
|
||||||
|
>>> z7=Class3(123)
|
||||||
|
>>> dir(z7)==dir(Class3)
|
||||||
|
False #У класса Class3 — нет 'data'
|
||||||
|
>>> dir(z7.fio)
|
||||||
|
['__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']
|
||||||
|
>>> 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'] #rozden был добавлен только к экземпляру z7, а не к классу Class3, если атрибут или метод добавлены к классу то к экземпляру автоматически тоже
|
||||||
|
```
|
||||||
|
|
||||||
|
## 6 Выявление родительских классов
|
||||||
|
|
||||||
|
```py
|
||||||
|
>>> Class3.__bases__
|
||||||
|
(<class '__main__.Class2'>,)
|
||||||
|
>>> Class2.__bases__
|
||||||
|
(<class '__main__.Class1'>,)
|
||||||
|
>>> Class1.__bases__
|
||||||
|
(<class 'object'>,) #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) #позволяет контролировать доступ к атрибуту через методы: obj.svojstvo → вызывает chten(). obj.svojstvo = 5 → вызывает zapis(5). del obj.svojstvo → вызывает stiran()
|
||||||
|
...
|
||||||
|
...
|
||||||
|
>>> exempl=Class4(12)
|
||||||
|
>>> exempl.svojstvo
|
||||||
|
12
|
||||||
|
>>> exempl.svojstvo=45
|
||||||
|
>>> print(exempl.svojstvo)
|
||||||
|
45
|
||||||
|
del exempl.svojstvo #атрибут __prm больше не существует
|
||||||
|
exempl.svojstvo
|
||||||
|
Traceback (most recent call last):
|
||||||
|
File "<pyshell#40>", line 1, in <module>
|
||||||
|
exempl.svojstvo
|
||||||
|
File "<pyshell#33>", 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])
|
||||||
|
```
|
||||||
|
|
||||||
|
Была создана основная программа для формирования САУ с помощью модуля SAU:
|
||||||
|
|
||||||
|
```py
|
||||||
|
###main_SAU
|
||||||
|
|
||||||
|
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])
|
||||||
|
|
||||||
|
import pylab
|
||||||
|
pylab.plot(yt)
|
||||||
|
pylab.show()
|
||||||
|
```
|
||||||
|
|
||||||
|
Был запущен модуль MAIN_SAU
|
||||||
|
|
||||||
|
```py
|
||||||
|
= RESTART: C:\Users\Professional\Desktop\python-labs\TEMA9\main_SAU.py
|
||||||
|
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
|
||||||
|
```
|
||||||
|

|
||||||
|
|
||||||
|
## 9 Завершение работы
|
||||||
|
|
||||||
|
Сеанс в IDLE был завершен!
|
||||||
|
|
||||||
@ -0,0 +1,99 @@
|
|||||||
|
## Общее контрольное задание по теме 9
|
||||||
|
|
||||||
|
Анисенков Павел А-01-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
Создайте и запишите в модуль класс, содержащий следующие компоненты:
|
||||||
|
|
||||||
|
- конструктор, задающий четырем атрибутам (fio, otdel, dolzhnost, oklad), представляющим фамилии сотрудников, название отделов, названия должностей сотрудников и размеры их окладов, некоторые начальные значения;
|
||||||
|
|
||||||
|
- метод для обеспечения операции повышения оклада сотрудника на заданное значение;
|
||||||
|
|
||||||
|
- метод для обеспечения перевода сотрудника из одного отдела в другой;
|
||||||
|
|
||||||
|
- метод для изменения должности сотрудника;
|
||||||
|
|
||||||
|
- свойство, содержащее перечень (список) поощрений сотрудника.
|
||||||
|
|
||||||
|
Создайте 2 экземпляра класса, задайте им некоторые значения атрибутов и свойства. Отобра-зите эти значения. Попробуйте с этими экземплярами операции перевода из отдела в отдел, изменения должности и оклада, объявления благодарности.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
|
||||||
|
Программа записанная в модуль:
|
||||||
|
|
||||||
|
```py
|
||||||
|
class Sotrudnik:
|
||||||
|
|
||||||
|
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||||
|
self.fio = fio
|
||||||
|
self.otdel = otdel
|
||||||
|
self.dolzhnost = dolzhnost
|
||||||
|
self.oklad = oklad
|
||||||
|
self.__pooshchreniya = []# Приватный атрибут для хранения поощрений Чтобы запретить прямое изменение списка поощрений извне.Все операции (добавление, чтение, очистка) происходят только через свойство pooshchreniya, где контролируется логика — например, при emp.pooshchreniya = "Премия" — значение добавляется в список, а не перезаписывает его.(публичный может сломать код emp.pooshchreniya = 123 ← тип не тот emp.pooshchreniya = None ← сломать логику)
|
||||||
|
|
||||||
|
def __chtenie_pooshchreniy(self): #возвращает список
|
||||||
|
return self.__pooshchreniya
|
||||||
|
|
||||||
|
def __zapis_pooshchreniy(self, pooshchrenie): #добавляет поощрение
|
||||||
|
self.__pooshchreniya.append(pooshchrenie)
|
||||||
|
|
||||||
|
def __stiran_pooshchreniy(self): # очищает список
|
||||||
|
self.__pooshchreniya = []
|
||||||
|
|
||||||
|
pooshchreniya = property(__chtenie_pooshchreniy, __zapis_pooshchreniy, __stiran_pooshchreniy, "Список поощрений сотрудника")
|
||||||
|
#Методы изменения данных:
|
||||||
|
def povysit_oklad(self, summa):
|
||||||
|
self.oklad += summa
|
||||||
|
|
||||||
|
def perevod_v_otdel(self, novyy_otdel):
|
||||||
|
self.otdel = novyy_otdel
|
||||||
|
|
||||||
|
def izmenit_dolzhnost(self, novaya_dolzhnost):
|
||||||
|
self.dolzhnost = novaya_dolzhnost
|
||||||
|
|
||||||
|
def __repr__(self): #чтобыпросто писать print(emp1) — и видеть все данные
|
||||||
|
return (f"Сотрудник: {self.fio}, Отдел: {self.otdel}, "
|
||||||
|
f"Должность: {self.dolzhnost}, Оклад: {self.oklad}, "
|
||||||
|
f"Поощрения: {self.pooshchreniya}")
|
||||||
|
|
||||||
|
# Создание экземпляров
|
||||||
|
emp1 = Sotrudnik("Иванова И.И.", "Секретариат", "Разносчица бумажек", 50000)
|
||||||
|
emp2 = Sotrudnik("Петрова А.С.", "Секретариат", "Разносчица кофе", 80000)
|
||||||
|
|
||||||
|
# Задание начальных поощрений
|
||||||
|
emp1.pooshchreniya = "Благодарность" #накапливает поощрения
|
||||||
|
emp2.pooshchreniya = "Премия"
|
||||||
|
emp2.pooshchreniya = "Премия 2"
|
||||||
|
|
||||||
|
# Отображение начальных значений
|
||||||
|
print("Начальные данные ")
|
||||||
|
print(emp1)
|
||||||
|
print(emp2)
|
||||||
|
|
||||||
|
# Операции с экземплярами
|
||||||
|
|
||||||
|
# Сотрудник 1: Повышение оклада и перевод
|
||||||
|
emp1.povysit_oklad(10000)
|
||||||
|
emp1.perevod_v_otdel("Генсекритариат")
|
||||||
|
|
||||||
|
# Сотрудник 2: Изменение должности и объявление благодарности
|
||||||
|
emp2.izmenit_dolzhnost("Старшая секретарша")
|
||||||
|
emp2.pooshchreniya = "Благодарность от руководства за вкусный кофе"
|
||||||
|
|
||||||
|
# Отображение измененных значений
|
||||||
|
print("Измененные данные")
|
||||||
|
print(emp1)
|
||||||
|
print(emp2)
|
||||||
|
```
|
||||||
|
|
||||||
|
Отображение результата:
|
||||||
|
|
||||||
|
```py
|
||||||
|
= RESTART: C:\Users\Professional\Desktop\python-labs\TEMA9\task.py
|
||||||
|
Начальные данные
|
||||||
|
Сотрудник: Иванова И.И., Отдел: Секретариат, Должность: Разносчица бумажек, Оклад: 50000, Поощрения: ['Благодарность']
|
||||||
|
Сотрудник: Петрова А.С., Отдел: Секретариат, Должность: Разносчица кофе, Оклад: 80000, Поощрения: ['Премия', 'Премия 2']
|
||||||
|
Измененные данные
|
||||||
|
Сотрудник: Иванова И.И., Отдел: Генсекритариат, Должность: Разносчица бумажек, Оклад: 60000, Поощрения: ['Благодарность']
|
||||||
|
Сотрудник: Петрова А.С., Отдел: Секретариат, Должность: Старшая секретарша, Оклад: 80000, Поощрения: ['Премия', 'Премия 2', 'Благодарность от руководства за вкусный кофе']
|
||||||
|
```
|
||||||
@ -0,0 +1,62 @@
|
|||||||
|
class Sotrudnik:
|
||||||
|
|
||||||
|
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||||
|
self.fio = fio
|
||||||
|
self.otdel = otdel
|
||||||
|
self.dolzhnost = dolzhnost
|
||||||
|
self.oklad = oklad
|
||||||
|
self.__pooshchreniya = []# Приватный атрибут для хранения поощрений
|
||||||
|
|
||||||
|
def __chtenie_pooshchreniy(self): #возвращает список
|
||||||
|
return self.__pooshchreniya
|
||||||
|
|
||||||
|
def __zapis_pooshchreniy(self, pooshchrenie): #добавляет поощрение
|
||||||
|
self.__pooshchreniya.append(pooshchrenie)
|
||||||
|
|
||||||
|
def __stiran_pooshchreniy(self): # очищает список
|
||||||
|
self.__pooshchreniya = []
|
||||||
|
|
||||||
|
pooshchreniya = property(__chtenie_pooshchreniy, __zapis_pooshchreniy, __stiran_pooshchreniy, "Список поощрений сотрудника")
|
||||||
|
#Методы изменения данных:
|
||||||
|
def povysit_oklad(self, summa):
|
||||||
|
self.oklad += summa
|
||||||
|
|
||||||
|
def perevod_v_otdel(self, novyy_otdel):
|
||||||
|
self.otdel = novyy_otdel
|
||||||
|
|
||||||
|
def izmenit_dolzhnost(self, novaya_dolzhnost):
|
||||||
|
self.dolzhnost = novaya_dolzhnost
|
||||||
|
|
||||||
|
def __repr__(self): #чтобыпросто писать print(emp1) — и видеть все данные
|
||||||
|
return (f"Сотрудник: {self.fio}, Отдел: {self.otdel}, "
|
||||||
|
f"Должность: {self.dolzhnost}, Оклад: {self.oklad}, "
|
||||||
|
f"Поощрения: {self.pooshchreniya}")
|
||||||
|
|
||||||
|
# Создание экземпляров
|
||||||
|
emp1 = Sotrudnik("Иванова И.И.", "Секретариат", "Разносчица бумажек", 50000)
|
||||||
|
emp2 = Sotrudnik("Петрова А.С.", "Секретариат", "Разносчица кофе", 80000)
|
||||||
|
|
||||||
|
# Задание начальных поощрений
|
||||||
|
emp1.pooshchreniya = "Благодарность" #накапливает поощрения
|
||||||
|
emp2.pooshchreniya = "Премия"
|
||||||
|
emp2.pooshchreniya = "Премия 2"
|
||||||
|
|
||||||
|
# Отображение начальных значений
|
||||||
|
print("Начальные данные ")
|
||||||
|
print(emp1)
|
||||||
|
print(emp2)
|
||||||
|
|
||||||
|
# Операции с экземплярами
|
||||||
|
|
||||||
|
# Сотрудник 1: Повышение оклада и перевод
|
||||||
|
emp1.povysit_oklad(10000)
|
||||||
|
emp1.perevod_v_otdel("Генсекритариат")
|
||||||
|
|
||||||
|
# Сотрудник 2: Изменение должности и объявление благодарности
|
||||||
|
emp2.izmenit_dolzhnost("Старшая секретарша")
|
||||||
|
emp2.pooshchreniya = "Благодарность от руководства за вкусный кофе"
|
||||||
|
|
||||||
|
# Отображение измененных значений
|
||||||
|
print("Измененные данные")
|
||||||
|
print(emp1)
|
||||||
|
print(emp2)
|
||||||
Загрузка…
Ссылка в новой задаче