diff --git a/TEMA9/M0.py b/TEMA9/M0.py new file mode 100644 index 0000000..3786799 --- /dev/null +++ b/TEMA9/M0.py @@ -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") diff --git a/TEMA9/M1.py b/TEMA9/M1.py new file mode 100644 index 0000000..2878618 --- /dev/null +++ b/TEMA9/M1.py @@ -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 diff --git a/TEMA9/M2.py b/TEMA9/M2.py new file mode 100644 index 0000000..0f60e76 --- /dev/null +++ b/TEMA9/M2.py @@ -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 diff --git a/TEMA9/Mod3.py b/TEMA9/Mod3.py new file mode 100644 index 0000000..0ab7e2e --- /dev/null +++ b/TEMA9/Mod3.py @@ -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) diff --git a/TEMA9/RES2a.bin b/TEMA9/RES2a.bin new file mode 100644 index 0000000..5068d15 Binary files /dev/null and b/TEMA9/RES2a.bin differ diff --git a/TEMA9/SAU.png b/TEMA9/SAU.png new file mode 100644 index 0000000..68a4cd5 Binary files /dev/null and b/TEMA9/SAU.png differ diff --git a/TEMA9/SAU.py b/TEMA9/SAU.py new file mode 100644 index 0000000..6f0cc48 --- /dev/null +++ b/TEMA9/SAU.py @@ -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]) diff --git a/TEMA9/data1.txt b/TEMA9/data1.txt new file mode 100644 index 0000000..5ae6de3 --- /dev/null +++ b/TEMA9/data1.txt @@ -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 \ No newline at end of file diff --git a/TEMA9/data11.txt b/TEMA9/data11.txt new file mode 100644 index 0000000..16a1769 --- /dev/null +++ b/TEMA9/data11.txt @@ -0,0 +1,6 @@ +3.5 +4.8 +5.0 +6.7 +3.3 +7.2 diff --git a/TEMA9/data12.txt b/TEMA9/data12.txt new file mode 100644 index 0000000..ca3f0aa --- /dev/null +++ b/TEMA9/data12.txt @@ -0,0 +1,6 @@ +1.2 +-2.1 +2.3 +1.1 +0.0 +-1.5 diff --git a/TEMA9/data2.txt b/TEMA9/data2.txt new file mode 100644 index 0000000..72b8c96 --- /dev/null +++ b/TEMA9/data2.txt @@ -0,0 +1,4 @@ +10 20 30 +15.5 -5 +0 25 35.7 40 +12.3 18.9 \ No newline at end of file diff --git a/TEMA9/main_SAU.py b/TEMA9/main_SAU.py new file mode 100644 index 0000000..73e6070 --- /dev/null +++ b/TEMA9/main_SAU.py @@ -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() diff --git a/TEMA9/report.md b/TEMA9/report.md new file mode 100644 index 0000000..09ccd74 --- /dev/null +++ b/TEMA9/report.md @@ -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 "", line 1, in + 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__ +(,) +>>> Class2.__bases__ +(,) +>>> Class1.__bases__ +(,) #object — корень всей иерархии классов в нем определены все базовые методы +>>> Class3.__mro__ +(, , , ) +>>> ZeroDivisionError.__mro__ +(, , , , ) +``` + +## 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 "", line 1, in + exempl.svojstvo + File "", 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 +``` +![](SAU.png) + +## 9 Завершение работы + +Сеанс в IDLE был завершен! + diff --git a/TEMA9/task.md b/TEMA9/task.md new file mode 100644 index 0000000..cddc3ce --- /dev/null +++ b/TEMA9/task.md @@ -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', 'Благодарность от руководства за вкусный кофе'] +``` \ No newline at end of file diff --git a/TEMA9/task.py b/TEMA9/task.py new file mode 100644 index 0000000..464655f --- /dev/null +++ b/TEMA9/task.py @@ -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)