у Вас талант к преподаванию, весь материал излагаете последовательно и доходчиво
@alenwar5123 Жыл бұрын
Если кому-то сложно освоить материал, что-то не получается, то лучше отдохнуть и вернуться к этому уроку через время Это должно помочь
@ДмитрийСергеев-л6г3 жыл бұрын
Сергей, спасибо за ваши видео!!! Просто супер!!! Самое комплексное и понятное объяснение!!! Все ваши видео смотрю!!!
@АндрейЛитвиненко-г3э2 жыл бұрын
Наконец-то нормально объяснили как это все работает. Спасибо!
@qwertymegaforce90882 жыл бұрын
Как же шикарно все объяснено, просто по полочкам. Респект!!!
@non53092 жыл бұрын
Много где облазил, но объяснения от автора, имхо, лучшее что есть на ютюбе на русском языке. Если бы был поллноценный курс на степике или типа того, обязательно заплатил бы! Спасибо!
@leshen_show2 жыл бұрын
Сергей, мы вас рассекретили, разлогиньтесь)
@alex_semin2 жыл бұрын
@@leshen_show не, а что? бизнес, ничего личного! А так Сергею огромное спасибо за курс))
@denchik553 Жыл бұрын
Є ще egoroff_channel
@jaksonmillka4 ай бұрын
Урок #9 = Пройден Этот урок полностью поменял мой взгляд на сеттеры и геттеры. Это просто имхо. Даже не мог подозревать, что все настолько может быть упрощенным. P.S. Я уже чуток потренировался, и как же я был в шоке от того, как же это удобно. Буду теперь на постоянной основе его использовать. Спасибо Вам, Сергей. Жму руку🤝 И ведь это только 9-й урок (10 видео)...я в предкушении, что будет в следующих 30 уроках)
@n0rmaLman3 жыл бұрын
Спасибо. Про декораторы знал, но то что это методы класса property - это нигде не разу не встречал. Было интересно посмотреть как это работает изнутри.
@Blendershick Жыл бұрын
Невероятно простая подача сложного материала все понятно! Спасибо!
@AdmiralUshakovvv3 жыл бұрын
второй раз вы лучше это обьяснили, чем в первом плейлисте)))
@vlakin13 жыл бұрын
ты просто гениально все объясняешь ! спасибище!!!
@ДмитрийТочилкин3 жыл бұрын
Скорее всего вопрос, который я задам, опытным коллегам покажется максимально глупым, однако мой жизненный опыт говорит о том, что лучше показаться глупым в обучении, чем оказаться глупым в "бою". Посему вопрос: для чего сначала запрещать доступ к атрибутам извне посредством присвоения им статуса private, а потом достаточно хитрым методом реализовать через декоратор в классе возможность обеспечить доступ к этим же самым атрибутам опять-таки извне? Если не сложно, не могли бы описать какой-нибудь пример из реальной практики, когда это необходимо? Заранее большое спасибо за ответ и огромное уважение и благодарность автору за этот замечательный курс!
@selfedu_rus3 жыл бұрын
Спасибо! Классический вопрос. Пусть есть класс Window - окно на экране. У него есть два свойства height и width (высота и ширина), мы создаем объект w = Window(), а затем, меняем высоту w.height = 200. Что должно произойти при этом действии? Во-первых, измениться соответствующее свойство (с проверкой корректности данных) и, во-вторых, измениться в размерах само окно на экране. Сделать это через обычную переменную с доступом извне не получится.
@andrewharazdowskyy47713 жыл бұрын
Дмитрий! Я, как и Вы - учусь и точно также оочень длительное время задавался именно этим вопросом... пока не понял его полностью! Если Вас не устроил ответ Учителя - могу Вам предложить обьяснение от себя-Чайника... ) может Вам легче будет понять - как художник - художника...)
@volleyy11243 жыл бұрын
Я думаю что можно впихнуть какие то проверки или действия перед передачей или записью
@maksshcherbakov85332 жыл бұрын
@@andrewharazdowskyy4771 я не Дмитрий, но был бы рад еще одному объяснению
@andrewharazdowskyy47712 жыл бұрын
@@maksshcherbakov8533 Макс! Мне лично хорошо запоминаются жизненные примеры. Допустим мы с Вами пишем комплекс для проектирования мебели. Запоминаем: для производства мебели нам поставляют плиты размером 2 х 3 м и допустим - одинаковой толщины - 20 мм. Вы - пишете модуль для подсчета расхода материала (наших мебельных плит). Вы создаете класс Plate (плиты) c локальными свойствами x, y, z (ширина, высота, толщина). Каждый раз - когда я создаю экземпляр Вашего класса (это значит - я отрезал кусок плиты) - Вы делаете расход материала. А теперь Главное: если свойства x, y, z будут public - я могу создавать экземпляры (отрезать куски) размером больше допустимого... и даже по ошибке - могу заказать кусок (попробовать создать экземпляр) a = Plate(1, "Hello", 30). Сделав все три параметра x, y, z - приватными - Вы можете перед каждым созданием экземпляра класса проверять в сеттере - на правильность типа (например только int), на соответствие допустимому диапазону (например - ширина до 3 м), можете запретить изменение параметра z - толщине (все плиты по договоренности - одинаковой толщины 20 мм). С одной стороны - у нас инкапсуляция - с другой стороны - модуль же должен иметь связь с внешним миром! Вот мое лично субьективное понимание сути вопроса. Попробуйте найти некоторые подтверждения моих мыслей в базовом (начальном) уроке по сеттерам и геттерам.
@Dayplaylist2 жыл бұрын
Хороший и полезный ролик 😌 как дойду до наследования дам свой полный фидбэк на обновленный курс по ооп😌 но в любом случае сразу благодарю автора!!!!видно что работа огромная проделана
@agility35543 жыл бұрын
2.5 недели назад не понял, что такое декораторы в итоге прошел весь ваш курс на степике по питону. Вернулся и теперь все стало ясно.
@misha82802 жыл бұрын
ссылку на курс можно?)
@nailnail10002 жыл бұрын
Автор, желаю тебе миллион подписчиков за втой труд!
@ned.sergio8454 Жыл бұрын
Спасибо! Очень понятно объясняете, сразу всё ясно
@krekerstna19417 ай бұрын
Методы property возвращают объект property, поэтому следующий код одинаковый: old = property(get_old, set_old) равен old = property() old = old.getter(get_old) old = old.setter(set_old) равен old = property().getter(get_old).setter(set_old)
@sofiipochta4 ай бұрын
Спасибо, посмотрела!
@mihhail752 жыл бұрын
Cпасибо за отличный курс. Если есть ещё здесь старички как я, то за шестёрёнкой на видео можно понизить скорость до 0.75, как я делаю ;)
@fahrenheit18632 жыл бұрын
Декоратор очень полезный, сокращает количество кода. Уже испробовал в модели Django проекта.
@MatveyRF11 ай бұрын
спасибо за Вашу работу.
@Konstantin_Stalnov Жыл бұрын
Проще гораздо работать напрямую через set и get, плюс добавив docstring Реализация через property существенно усложняет сопровождение кода
@sergeizhigailov91555 ай бұрын
У меня появились 2 вопроса: на 8:30 вы говорите, что приоритет у объекта свойства property old выше, чем у создаваемой пары ключ-значение в словаре объекта класса Person. Однако, если мы создаем не пару p.__dict__['old'] = 'some string...', а пару p.__dict__['_Person__old'] = 'some string...', то значение ключа _Person__name в словаре отлично меняется с 35 на 'some string'. Вопросы: 1) Получается, дело не в приоритетности объекта свойства property, а в том, что мы изначально создавали в словаре и потом работали при помощи old = property (...) с атрибутами типа _Person__name и _Person__old (что соответствует self.__name и self.__old), а теперь пытаемся поменять self.__old в словаре на self.old , что выдает 2 разных ключа, что логично, так как мы работаем с разными аттрибутами. 2) Существует ли действительная приоритетность объектов свойства property перед простым заданием пары значений в словаре ({ключ: значение}) или объекты свойства property лучше использовать только для того, чтобы работать с вереницами сеттеров - геттеров - дилитеров? Поправьте, если неправ. И огромное спасибо за уроки!!!
@selfedu_rus5 ай бұрын
Здравствуйте! Конечно, когда вы обращаетесь по имени _Person__old, то это имя отличается от имени атрибута-свойства old, поэтому приоритеты здесь не включаются. Попробуйте то же самое с обычным атрибутом old. Здесь будет идти обращением именно к свойству (property), а не переменной. А вообще на такие вопросы вам с радостью ответят в сообществе ТГ-канала по Python (ссылка под видео).
@aleksandrsemenov17642 жыл бұрын
Очередной раз нашёл много того, чего не знал, спасибо!
@ЕрвандАгаджанян-в3к Жыл бұрын
Потрясающе!
@sega65742 жыл бұрын
спасибо тебе огромное, дорогой!
@АбрамШекельгрубер Жыл бұрын
Нормально! На других каналах, где повествуется эта тема, вообще ничего не понять.
@LAV4519 ай бұрын
Пошла жара ))
@vitalyvistovsky86612 жыл бұрын
Стільки інфи в 16 хв. Сергей в ударі!
@НикН-о7о3 жыл бұрын
Отлично, спасибо
@donfedor0073 жыл бұрын
Спасибо! Очень полезное видео!
@Dmitrii-Zhinzhilov Жыл бұрын
Сергей, благодарю!! 👍🔥
@agniusl2 жыл бұрын
Пора изменить название канала на Супер препод!
@mihail8575 Жыл бұрын
Не пойму чем простые геттеры и сеттеры 02:30 уступает этому 04:42 (property(get_old, set_old)) и уж нем более чем 13:26 (@property + @get_old). Последнее ну ни разу не выглядит проще и интуитивнее. Или я что-то не понимаю?
@alexandrmelnikov6434 Жыл бұрын
У меня пиявились знания )
@abdulloakramov7941 Жыл бұрын
👍👍👍👍 спасибо за урок
@andredru427810 ай бұрын
Спасибо. Понятно. Странно только - пользуемся вроде абстракцией в виде класса, но лезем ей в кишки (совсем не абстрактно).
@clqwnlesslxrd Жыл бұрын
Спасибо!
@krakoziabr6 ай бұрын
Вначале ролика сказали, что трудно следить за прописыванием каждому атрибуту методов геттер и сеттер. И в итоге прописали аналогично и свойство для атрибута и свойство.сеттер. Мысль чем это лучше\удобней в итоге не ясна, только тем что имя одно? По итогу так же для каждого атрибута прописывать свойство нужно, и чем это лучше?
@selfedu_rus6 ай бұрын
пользоваться потом проще, обращаеимся по одному имени и для записи и для чтения в этом удобство
@AM-vr6ej Жыл бұрын
все супер, доступно и понятно. спасибо. но почему не Age, а Old?))
@andrus3125 Жыл бұрын
how old are you
@bernardsoul89369 ай бұрын
Я правильно понимаю, что это нужно для того, что бы если мы заранее не знаем имя нового атрибута мы таким образом защищаем от изменений важные для работы класса атрибуты? Ну т.е. если пользователь в последствии создаст экземпляр класса, добавит в него атрибут old, то это никак не повлияет на атрибут самого класса. Таким образом у нас не пересекаются имена атрибутов и при желании можно изменить атрибут old самого класса, а не его экземпляра?
@MovieCutCinema8 ай бұрын
Может кто-то объяснить? Когда у нас в классе 3 переменных олд, почему не нарушается логика? Ведь обычно в таких случаях переменная просто меняет значение. 12:51
@Cygni7 Жыл бұрын
Отличное видео! Но остались вопросы. Ваш пример с Window (приведённый под другим комментарием). Нельзя ли вместо property использовать магический метод __set_attr__, в котором мы будем проверять, какое свойство мы изменяем, и если это width или height, то, соответственно, делаем то что надо. Заранее спасибо)
@selfedu_rus Жыл бұрын
Можно, но property позволяет разнести код по отдельным методам, что с точки зрения красоты куда лучше.
@Cygni7 Жыл бұрын
Спасибо, буду знать
@random_act Жыл бұрын
класс
@jamjam3337 Жыл бұрын
спасибо!
@bobby_ridge9 ай бұрын
Дорого времени суток, видео 🔥. Но есть вопрос: если сделать не __age, a age, то выходит ошибка, связанная с рекурсией. Можете пожалуйста объяснить почему?
@avaxxxxxxx7 ай бұрын
такой же вопрос, если не ошибаюсь в предыдущих роликах автор обговаривал эту ошибку, но не помню где именно
@Mikhail-g3y2 жыл бұрын
Немного не понял вот этого: old = property() old = old.setter(set_old) old = old.getter(get_old) Разве мы каждой строчкой не переопределяем атрибут old?
@podgorniy.r2 жыл бұрын
Тоже обратил на это внимание. Мой уровень знаний пока не позволяет понять как работает данный объект. Что происходит при вызове экземпляр класса old? Как он сам определяет какой метод вызвать...
@xandrviking11136 ай бұрын
Спасибо за уроки 🖖👍
@leva16722 ай бұрын
Все равно не понятно: У себя в пайчарме 2 класса создал, один как у вас в примере, с приватными свойствами, которые становятся доступными через геттер и сеттер, и у которых мы меняем названия с помощью property чтобы было проще обращаться. Второй класс, который использует просто публичные атрибуты self.name и self.old. Вот теперь вопрос - а какая разница? Получается в первом примере мы сначала по сути сделали их приватными, а потом обратно с помощью нехилых таких костылей сделали публичными. В первом примере 13 строк кода, и по сути все атрибуты - публичные, потому что их можно поменять обратившись таким образом - p.old = 30 (просто тут old ссылается на сеттер, которому разрешено поменять приватный атрибут self.__old). Во втором примере я просто прописал публичный атрибут self.old и по сути меняю его такой же строкой кода - p.old = 30. Но тут всего 4 строки кода. Я понял задумку с приватными атрибутами и сеттерами , геттерами (хотя тут тоже логика, да? - делать недоступными, чтобы потом опять сделать доступными. Но тут хоть одну причину вижу - чтобы явно их не менять), но логику с property не пойму все равно. Тут же все тоже самое что и с обычными публичными атрибутами в плане написания кода. В первом примере чтобы узнать old я напишу - print(p.old) И во втором примере я напишу то же самое - print(p.old). Тогда зачем все это? (Ниже разъяснения я прочитал, но там все равно не понятно)
@v_alik2 жыл бұрын
Добрый день! Спасибо за вашу работу. Прошу ответить на пару вопросов, если Вас не затруднит. 1) Подскажите, декоратор @property обязательно только перед геттером стоит ( 14:25 )? И почему именно перед ним? Исторически сложилось? 2) В каком случае возможно использование декоратора @old.getter ? Заранее благодарю!
@selfedu_rus2 жыл бұрын
Возможно, это восходит к дескрипторам (данных и не данных), где метод get() строго обязателен. А, вообще, следует воспринимать как элемент языка и просто запомнить. Этот декоратор можно использовать для переопределения геттера.
@v_alik2 жыл бұрын
@@selfedu_rus но даже при переопределении геттера, декоратор property будет у "старого" геттера?
@selfedu_rus2 жыл бұрын
@@v_alik Вот, переопределется: class Person: def __init__(self, name, old): self.__name = name self.__old = old @property def get_old(self): return self.__old @get_old.setter def get_old(self, old): self.__old = old @get_old.getter def get_old(self): return self.__old + 10
@v_alik2 жыл бұрын
@@selfedu_rus Тогда @property def get_old(self): return self.__old перестает быть геттером? и тогда зачем он остался, почему бы не стереть?
@maximkuchiga1412 жыл бұрын
Добрый день! Подскажите пожалуйста, почему вот такая ошибка. Если один аргумент в сеттере то все ок, если два то такая ошибка.. Traceback (most recent call last): File "/Users/maxvolkoff/PyPro/teach_n0/classes_4.py", line 18, in pt.min_max = (1, 2) TypeError: Class.min_max() missing 1 required positional argument: 'max'
@maximkuchiga1412 жыл бұрын
вот такой вот код: class Class: def __init__(self, min, max): self.__min = min self.__max = max @property def min_max(self): return self.__max @min_max.setter def min_max(self, min, max): self.__max = max self.__min = min pt = Class(0, 10) pt.min_max = (1, 2) print(pt.min_max) print(pt.__dict__)
@selfedu_rus2 жыл бұрын
эту конкретику лучше спрашивать в сообществе телеграм-канала по Python (ссылка под видео)
@colossalhate66107 ай бұрын
Так, теперь вопрос на засыпку. Зачем все это делать в данном примере, если мы можем в теле класса написать self.old вместо self.__old. По сути, к этому же и пришли?
@selfedu_rus7 ай бұрын
извне не можем, только внутри (хотя извне тоже можно исхитриться, но это уже будет на совести программиста); приватные переменные - это не защита от хакеров, это пометка для программиста, что использовать только внутри класса
@colossalhate66107 ай бұрын
@@selfedu_rus пересмотрел и понял. Если бы мы не задавали сеттер через property, то у нас создавалась бы новая переменная в самом объекте, а не изменялся бы атрибут класса. Пропустил момент про приоритет property. Спасибо за уроки!
@Xmike499-5 ай бұрын
Можно вопрос? сколько вам сейчас лет?
@mrup71923 жыл бұрын
Спасибо ! В отличии от урока в предыдущем курсе по ООП этот действительно более понятен, посмотрел с удовольствием! ) Однако хочется прояснить один момент: В классе когда мы делаем свойства через декораторы... old = property() old = old.getter(fun) old = old.setter(fun2) Правильно ли я понимаю, что здесь происходит как бы 'напихивание декорированных методов в переменную - old' т. е это не нужно воспринимать как обычное присваивание. Имею в виду, что если бы имя - 'old' не было объектом property то такое присваивание каждый раз связывало бы с этим именем новый метод. Какой-то протокол под капотом ?
@selfedu_rus3 жыл бұрын
Да, все верно, old - это общий декоратор, в котором будет два метода для setter и getter
@thepseudonym.3 жыл бұрын
@@selfedu_rus спасибо.
@MOIS3Y-YT Жыл бұрын
Почему когда мы обращаемся к сеттеру, через оператор присваивания = происходит вызов функции. У меня одно объяснение он переопределен в классе property и выполняет другое действие как скобочки (). По аналогии с переопределением __add__, когда + будет делать заданный функционал а не сложение/конкатенацию. Я прав?
@selfedu_rus Жыл бұрын
не понял до конца вопроса, может поможет то, что объекты-свойства имеют при обращении более высокий приоритет, чем обычный атрибуты-переменные
@ardauqq5915 Жыл бұрын
Сергей, не совсем понял на 7:37 речь же идет о локальных атрибутах, а не о локальных свойствах или не так?
@selfedu_rus Жыл бұрын
это одно и то же
@АбрамШекельгрубер Жыл бұрын
А вообще - странная конструкция получается. Приватные атрибуты подразумевают отсутствие доступа к ним извне. Но мы делаем "property", в результате чего получаем доступ к приватным атрибутам извне. Т.е. делам приватный атрибут публичным.
@dmitriynayanov6428 Жыл бұрын
зато теперь можно наложить логику изменения или чтения приватного значения. В публичном можно было бы поменять на любое значение, а тут теперь можем наложить какое-нибудь условие
@lemonade022411 ай бұрын
Ну во-первых, ту же логику расширить на protected аргументы. Во-вторых в этой же логике вы можете докрутить дополнительные проверки, эксепшны и так далее
@gienek_mscislawski3 жыл бұрын
Спасибо! А если всё то же самое нужно и для переменной __name, то неужели придётся дублировать код?
@GeoRomable3 жыл бұрын
Тоже очень интересует. Я попробовал продублировать декораторы для переменной __name и значения переменных в консоли стали равны (__old == __name ).
@TheLazyEagle3 жыл бұрын
Только def old надо менять на def name. @property def name(self); return self.__name; @name.setter def name(self, value); self.__name = value
@gienek_mscislawski3 жыл бұрын
@@TheLazyEagle собственно, я так и предполагал, что не есть круто, по моему мнению.
@selfedu_rus3 жыл бұрын
совершенно верно, придется дублировать, поэтому когда много разных свойств, то лучше использовать уже дескрипторы, речь о них далее )
@TheLazyEagle3 жыл бұрын
@@gienek_mscislawski Ну да, если очень много приватных переменных, то код начинает расти.
@nomadicus77 Жыл бұрын
Рекомендую тем кто в замешательстве, как был я паралельно клацать в пайчарме и пробовать, а то столько всего в ООП что уже теряешь себя в пространстве)
@AdmiralUshakovvv3 жыл бұрын
вам надо записать видео по терминам в ооп, что такое атрибуты свойства, поля, методы, обькты, экземпляры, классы, так людям будет проще)
@МаксимПономарев-х3ф2 жыл бұрын
Первые два видео как раз об этом
@zakirovio Жыл бұрын
на данный момент не понятно почему нужно использовать приватные атрибуты, если их можно спокойно изменять при помощи сеттера или проперти?
@zakirovio Жыл бұрын
пока только пришло в голову в геттер или сеттер добавить проверку пароля, например добавить инпут введите кодовое слово и если есть совпадение, то можно извлечь или переопределить свойство...
@selfedu_rus Жыл бұрын
меняете ширину окна, тогда дополнительно, например, можете в сеттере проверить, что это число и оно положительное
@zakirovio Жыл бұрын
@@selfedu_rus спасибо! нужно практиковать
@Grigorev842 жыл бұрын
Сергей, можно ли через property setter изменять два атрибута одновременно, например имеем две стороны прямоугольника А и В. В примере у Вас нужно делать свойство на каждый атрибут, а чисто логично бы сделать одной свойство к на обе стороны прямоугольника... Спасибо заранее.
@selfedu_rus2 жыл бұрын
да, можно, если аргументом передавать кортеж, а в функции его значения присваивать соответствующим свойствам объекта
@Grigorev842 жыл бұрын
@@selfedu_rus а Вы не могли бы кусочек такого кода на обозрение представить, пожалуйста))
@@Grigorev84 Подскажите, пожалуйста, почему в сеттере вы используете nums, а не *nums?
@nomadicus77 Жыл бұрын
День добрый, уважаемый Сергей есть вопрос. А property в 5 подвиге нам пришлось как бы дублировать отдельно для width и height тоесть получилось для одного сетер и гетер и для другого сетер и геттер а нельза было для двух обьектов-свойств записать один геттер и сеттер или для каждого объекта свойства должен быть отдельный геттер и сеттер?
@selfedu_rus Жыл бұрын
Можно и одно, тогда передавать придется сразу два значения как кортеж и читать тоже в виде кортежа.
@bekasenko2 жыл бұрын
Спасибо за видео, все очень понятно, но есть вопрос: можно ли таким образом в сеттер передать два значения? Допустим у на с класс Poіnt, у точки две координаты, можно через @property задават два значения?
@selfedu_rus2 жыл бұрын
да, можно, например, через кортеж
@bekasenko2 жыл бұрын
@@selfedu_rusспасибо, сработало
@zakirovio Жыл бұрын
Получается, к методам с одинаковым именем применяются разные декораторы, которые делают из метода объект property. Интерпретатор понимает какой метод исполнять, в зависимости какой оператор был использован: оператор присвоения - setter, оператор del - deleter, без оператора - getter?
@selfedu_rus Жыл бұрын
имя метода - это лишь ссылка на объект-функцию класса, поэтому все эти ссылки просто сохраняются в декораторах.
@zakirovio Жыл бұрын
@@AntonyKondr я имел ввиду при вызове в глобальном пространстве имен
@lemonade022411 ай бұрын
@@zakirovio вероятно тут все завязано на сигнатуры. Вы можете без всяких классов написать кучу просто функций с одинаковым именем но разными аргументами на вход - интерпретатор посчитает их как разные функции и будет выбирать исходя из ситуации нужную. Рызные декораторы над объявленной функцией так же меняют сигнатуру, получается похожая логика
@zakirovio11 ай бұрын
@@lemonade0224при определении множества функций с одинаковыми именами, вызываться будет только последняя, ее область видимости будет перекрывать другие
@zakirovio11 ай бұрын
объект класса property скорее всего имеет доступ к ссылкам этих одноименных методов и при использовании определенного оператора или инструкции применяет setter. getter или deleter
@SLSRPPRO2 жыл бұрын
с 3 - го раза понял и освоил тему ахах
@Antiqua-Greek-Latin Жыл бұрын
не очень все-таки понятно зачем нужен этот декоратор. Получается, что с помощью него осуществляется доступ к защищенным свойствам. Но можно просто убрать двойное нижнее подчеркивание впереди и получится тот же эффект, без нагромождения сеттеров и геттеров. Разве что в самих этих функциях можно вставлять дополнительные условия проверки на присвоение определенных значений.
@selfedu_rus Жыл бұрын
см. курс по Django и Flask - там они на каждом шагу ))
@gayratsaidakhmedov5451 Жыл бұрын
спасибо
@ibrahimoglu3 жыл бұрын
👍
@mellicape3 жыл бұрын
Сергей, сколько вы занимаетесь питоном? Интересно знать сколько нужно заниматься, чтоб так знать И спасибо вам за уроки, ваш труд неоценим
@selfedu_rus3 жыл бұрын
Спасибо! Я два года с ним знаком. Но здесь важен еще прежний опыт программирования, те кто уже знает другие языки быстрее изучают новые, т.к. много похожего ))
@vb52ru3 жыл бұрын
Не понял этого old = property() old = old.setter(set_get) old = old.getter(get_old) Как там присвоение идет...
@selfedu_rus3 жыл бұрын
Здесь нет никакого присваивания, всего лишь применяется декоратор setter к функции set_get и декоратор getter к функции get_old, чтобы обеспечить работу свойства old
@xximde2 жыл бұрын
Зачем делать два различных сеттера и геттера для двух приватных атрибутов? Разве мы не можем изменять и получать их оба через один сеттер/геттер?
@romankuznetsov4601 Жыл бұрын
Как ты себе это представляешь?
@Арина-я7п5с2 жыл бұрын
Добрый день. Вопрос, касающийся свойства property. Правильно ли я понимаю, что имеет значение порядок методов, указанных в свойстве property: на первом месте всегда метод, обеспечивающий получение значения атрибута, на втором - метод для задания значения атрибута, на третьем - метод для удаления значения атрибута, на четвертом - строка, содержащая документацию? property(getx, setx, delx, "I am the property.") И при изменении значения атрибута интерпретатор понимает, что необходимо вызвать метод, указанный на второй позиции свойства property, при зачитывании значения атрибута - метод, указанный на первой позиции свойства property и т.д. ?
@selfedu_rus2 жыл бұрын
вроде, да, верно расписали
@Сергей-ф3с2ц3 жыл бұрын
Добрый день, Сергей. Подскажите, вы планируете этот курс загружать на Stepik?
@selfedu_rus3 жыл бұрын
Пока нечего загружать ) Проработка курса - это около месяца упорной, рутиной работы. Сейчас не до этого.
@DeshkaSCP4 ай бұрын
доброе время суток, у меня вопрос: какой смысл делать переменную age закрытой, если мы по факту делаем с ней абсолютно тоже самое благодаря геттерам и сеттерам и вне кода класса работа с атрибутами никаким образом не меняется. Грубо говоря код из конца видео == тому чтобы переменную не делать закрытой
@osman3d4 ай бұрын
Идея в том, что теперь есть _возможность_ добавить нужный функционал во время записи/чтения атрибута, при этом пользователи класса (другие объекты/классы которые работают с нашим классом) не должны знать об этом, им это неважно. Они просто работают со свойствами, а мы, как создатели нашего класса можем эти свойства проверять, применять, обрабатывать любым нужным способом. Без гетера/сетера т.е. без этой дополнительной прослойки никакой возможности проверить что пишется в проперти и что оттуда достается - нет. Пример в видео несколько искусственный (потому что нет реальной задачи и в гетера и сетерах действительно ничего не делается) но при этом полностью достаточный для того чтобы показать как работает этот механизм в питоне. Это пример инкапсуляции.
@DeshkaSCP4 ай бұрын
@@osman3d я уже понял это на момент написания вашего комментария, просто сам недавно до классов дошел и на каждом из встреченных мною гайдов с ютуба толком тема закрытых переменных не растолкована. Спасибо за ответ в любом случае и знайте что вы абсолютно правы, на момент написания комментария я в классах не понимал ровным счетом ничего
@span4ev2 жыл бұрын
Посмотрел 4 минуты и не понимаю, в чём практический/сакральный/иной смысл этих манипуляций? Сначала мы сделали атрибуты приватными, затем расприватили их, чтобы иметь возможность обращаться к ним. Для чего? print(class_name.__dict__) показывает все наши "приватные" данные Единственное, что удобно = old = property(get_old, set_old), как дальнейшее использование чтения/записи используя прдемонстрированный в видео подход. Но стоит ли оно того, чтобы каждый раз это прописывать?
@hunterxvov4ik Жыл бұрын
тоже не понял.
@anrybolt67672 жыл бұрын
не увидел в прошлом видео объяснение гетеров и сетеров. Какое именно?
@anrybolt67672 жыл бұрын
вспомнил
@selfedu_rus2 жыл бұрын
kzbin.info/www/bejne/iJrTl6SYfZWYp7s
@01011968Desgner2 жыл бұрын
"Если в классе задан атрибут как объект-свойство, то в первую очередь выбирается оно...", a как тогда обратиться к локальному атрибуту с таким же именем?
@selfedu_rus2 жыл бұрын
только напрямую через __dict__, но обычно это не требуется, для этого и создается объект-свойство
@antonpinchuk94972 жыл бұрын
Здравствуйте, много где облазил - ничего не нашел. Надеюсь вы ответите.Почему мы не можем просто сразу создать метод private, почему нужно создавать публичный, а потом в нем делать return private. Вот допустим: @property def lvl(self): return self.__lvl, f'{dt.now() - self.__born}' @lvl.setter def lvl(self,numer): self.__lvl += numer Почему нельзя сразу создать def __lvl(self)? Заранее спасибо!
@selfedu_rus2 жыл бұрын
приватные атрибуты - это служебные (как правило, переменные) внутри класса и менять их извне не предполагается. Но если все же нужно получать или менять их значения, то прописывают сеттеры/геттеры или объекты-свойства, где выполняют дополнительную проверку на правильность передачи значений. Подробнее вам могут ответить в телеграм-канале по Python.
@МамонтовОлег-в9о3 жыл бұрын
етишкин кот!
@Dayplaylist2 жыл бұрын
Теория эволюции инкапсуляции в питоне за 16 минут))))
@1усфа Жыл бұрын
Зачем делать атрибут приватным, чтобы потом сделать пубоичным, каким он был изначально?
@selfedu_rus Жыл бұрын
Через property можно контролировать, что записываем и что отдаем.
@1усфа Жыл бұрын
@@selfedu_rus благодарю
@teacherit58402 жыл бұрын
Сергей, подскажите, если использовать property и не использовать атрибуты типа _ _private , то возникает ошибка так как у нас не будет присутствовать свойство , которое мы сделали с помощью property. К примеру у меня будет отсутствовать свойство health class Player: def __new__(cls, *args, **kwargs): print(f'Вызов метода __new__') return object.__new__(cls) def __init__(self,name, health, lvl): self.name = name self.health = health self.lvl = lvl @property def health(self): return self.health @health.setter def health(self, value): if value in (int,float): self.health = value # else: # raise TypeError('Здоровье должно быть написано цифрами') # p1= Player('Henry', 100, 5) print(p1.__dict__) print(p1.health) ---- > ОШИБКА
@teacherit58402 жыл бұрын
Получается чтобы использовать объект свойство нужно чтобы свойства быти всегда или protected или private?
@АлександрПрищепов-э7ю2 жыл бұрын
Что такое объект свойства, в этой теме про него говорят, но я никак не могу понять
@selfedu_rus2 жыл бұрын
@property
@xandrviking11136 ай бұрын
Я бы назвал поле old не свойство класса , а лямбда функция , которая работает двояко , в зависимости от чтения или записи. Просто очень похоже на поведение лямбда функции 🤔
@viv81ster2 жыл бұрын
После стиля C# стиль ООП пихтона смотрится конечно дико
@lemonade022411 ай бұрын
Вот эта конструкция не ясна old = property() old = old.setter(set_old) old = old.getter(get_old) Больно уж похоже на оверрайд одного и того же атрибута разными объектами
@lemonade022411 ай бұрын
BTW Вот такое вот old = property(get_old, set_old) Было бы понятнее
@sergioramos45622 жыл бұрын
спасибо) но если можно чуть помедленнее
@wasd13382 жыл бұрын
Касаемо функционального дублирования. Почему бы вместо докорирования геттеров и сеттеров не сделать сами геттеры и сеттеры приватными, и передавать в объект property приватные геттеры и сеттеры?
@johnmazepa Жыл бұрын
все равно не понимаю, зачем мы запрещаем программисту обращаться к свойствам объекта напрямую: p.old а потом городим еще кучу строчек, чтобы он все-таки потом мог обращаться к свойствам объекта визуально и по сути будто напрямую: p.old Почему бы нам сразу не разрешить ему иметь доступ к свойству напрямую?
@sadcat13272 жыл бұрын
Интересно, мы добавили "__" чтобы было нельзя взаимодействовать с атрибутом, а потом делаем так, что бы ми могли
@selfedu_rus2 жыл бұрын
да, но мы же не напрямую теперь с ним работаем, а через методы, а в методах можно дополнительные проверки выполнять
@ПашаКузнецов-в1з2 ай бұрын
очень всё сложно и запутанно. как это всё запомнить, решительно непонятно.
@СтепСтеп-п1л2 жыл бұрын
Всего один сеттер и все, тебе уже 35
@TheAKRET Жыл бұрын
Разве self.__name = name это локальное свойство а не приватный атрибут? kzbin.info/www/bejne/g6nZmoCtl6yfaasm00s,
@selfedu_rus Жыл бұрын
это и локальное свойство и приватный атрибут )
@dien000011 ай бұрын
В чем смысл такого функционала? Приватизировать, потом создавать декораторы, чтоб обращаться к методам класса, в чем смысл можете объяснить, чтоб я понимал в чем была цель такой логики в классах?
@юрийступак-х3о2 жыл бұрын
одно через другое через третье, фиг знает что., А где бл... постулаты пайтона - явное лучше неявного, Простое - лучше сложного. вопрос - нахера тьак все усложнять , мало вижу пользы в этом все по итогу Только голову ломать
@everything_is_simple8 Жыл бұрын
Бесполезная хрень Только кода больше . Написали одно потом написали второе в итоге и то и другое есть.
@dieselekin3 жыл бұрын
если честно - какого то облегчения так и не увидел. Вроде и без проперти всё прекрасно работает. Объём кода сильно не уменьшился
@selfedu_rus3 жыл бұрын
удобство в дальнейшем применении класса, конечно, если property выполняет не банальное присваивание, а некий алгоритм