#32. Менеджеры контекстов. Оператор with | Объектно-ориентированное программирование Python

  Рет қаралды 31,237

selfedu

selfedu

Күн бұрын

Пікірлер: 80
@bobby_ridge
@bobby_ridge 7 ай бұрын
8:50 - я и мой курсач по проге "Здесь конечно ошибка должна быть, но другая" Мужрые слова)😅
@micropp205
@micropp205 Жыл бұрын
Официально заявляю. Более полезных уроков по питону, я не видел. Двужище, ты лучший.
@gsm7490
@gsm7490 8 ай бұрын
У Вас отличный контент, Сергей. Давно присматривался к каналу, но я относительно недавно в питоне и раньше материал казался сложноватым. Но наконец дорос и смотрю теперь с удовольствием! Спасибо огромное!
@leonardodebrycho5795
@leonardodebrycho5795 3 ай бұрын
Спасибо вам большое Сергей!Уже скоро кончится курс по ООП, потом буду смотреть ваш курс по Django!Вы единственный человек который рассказывает подробно про все темы!
@mikhailihnatouski1215
@mikhailihnatouski1215 3 ай бұрын
Отличный пример избыточности, заложенной в ООП.
@andredru4278
@andredru4278 8 ай бұрын
Спасибо. Очень круто!
@sadkid4660
@sadkid4660 Жыл бұрын
Спасибо за реально крутое объяснение менеджера контекста.
@siarheiulas6969
@siarheiulas6969 Жыл бұрын
Большое спасибо за замечательный урок и за этот курс!!!
@jaksonmillka
@jaksonmillka Ай бұрын
Урок #32 = Пройден Этот урок меня настолько запутал, что пришлось обращаться к chatGPT, который тоже сначала не мог объяснить, ибо использовал примеры с sql, и т д, но я его попросил объяснить чтобы и дерево поняло, и в итоге, я все понял 🤣🤣 Менеджер with оказался очень даже полезным, и интересным :)
@pseudonym2
@pseudonym2 2 жыл бұрын
Спасибо за уроки!
@whiterabbit6211
@whiterabbit6211 10 ай бұрын
Классное объяснение!
@return_1101
@return_1101 2 жыл бұрын
Хорошие уроки. Нам ещё везёт что нет задании. ☺️☺️☺️
@t0xicav3ng3r4
@t0xicav3ng3r4 2 жыл бұрын
Великолепный урок! Спасибо за то, что Вы делаете)
@ЕрвандАгаджанян-в3к
@ЕрвандАгаджанян-в3к 2 жыл бұрын
Спасибо! Гениально!
@КириллЧе-я5ы
@КириллЧе-я5ы 10 ай бұрын
Ура! В питоне тоже есть идиомы владения🥴 безопасность повышаем🤪
@АлександрЛобанов-о2у
@АлександрЛобанов-о2у Жыл бұрын
Спасибо автору, лучший канал как по мне
@СарматПересветов
@СарматПересветов Жыл бұрын
спасибо! интересный урок
@ИринаВыпова-р9ц
@ИринаВыпова-р9ц 2 жыл бұрын
Большое спасибо. Очень интересно и полезно. Применю.
@mellicape
@mellicape 2 жыл бұрын
Спасибо за Ваши уроки. Вы очень хорошо объясняете. Скажите пожалуйста, Сергей, а вы планируете урок по асинхронному программированию на пайтон?
@selfedu_rus
@selfedu_rus 2 жыл бұрын
Спасибо! На очереди DRF и машинное обучение
@СергейСмирнов-ь8у
@СергейСмирнов-ь8у 2 жыл бұрын
Спасибо большое !
@ИоаннИщенко-р4о
@ИоаннИщенко-р4о Жыл бұрын
Думаю стоило упомянуть хотя-бы разок, что используя конструкцию среза вы получаете поверхностную копию списка, для полного копирования (например когда у вас список объектов) можно использовать deepcopy из библиотеки copy.
@zakirovio
@zakirovio Жыл бұрын
зачем, не в этом смысл урока и элементы списка неизменяемые переданы.
@АртемНиконов-у7я
@АртемНиконов-у7я Жыл бұрын
Сергей, а можете поподробнее сказать по поводу return False в exit
@selfedu_rus
@selfedu_rus Жыл бұрын
В ООП существуют различные исключения, которые генерируются командой raise. Когда оно появлявляется, то программа должна либо обработать его, либо оно будет подниматься до точки старта программы. Если и там не обработается, то программа завершит свою работу.
@АртемНиконов-у7я
@АртемНиконов-у7я Жыл бұрын
@@selfedu_rus Спасибо!
@kamilgabdullin
@kamilgabdullin 2 жыл бұрын
Большое спасибо! Хотлеось бы более подробно узнать про остальные праметры в __exit__
@selfedu_rus
@selfedu_rus 2 жыл бұрын
Спасибо! Документацию никто не отменял ))
@alexanderivlev8458
@alexanderivlev8458 Жыл бұрын
все понял, кром того как это работает: self.__v[:] = self.__temp
@rukigaki
@rukigaki Жыл бұрын
Переменная экземпляра класса DefendVector self.__v ссылается на тот же объект что и глобальная переменная v1(т.е. на лист [1, 2, 3]). И для того, чтобы не менять ссылки(т.е. переменные) автор меняет значения списка(в данном случае наш объект). Если две переменные ссылаются на один и тот же объект, это значит, что они зависят друг от друга, измени в одной переменной значение списка, оно также поменяется и в другой переменной, которая ссылается на тот же самый объект. Если бы автор записал так self.__v = self.__temp, это значило бы, что переменная __v ссылается уже абсолютно на другой объект, в данном случае это введет к тому, что переменная v1, осталась бы без изменений, так как __v это уже независимый объект, и v1 никаким образом не подтянет тех изменений, которые произошли в переменной __v.
@CitoFly3
@CitoFly3 7 ай бұрын
Тоже не понял этот момент, сейчас постараюсь разобраться
@ADen-qx6co
@ADen-qx6co 2 жыл бұрын
все понятно кроме self.__v[:] = self.__temp вроде более логичной выглядит запись self.__v = self.__temp но тогда self.__v приобретает ссылку на другой объект (изменяется id), а v1 продолжает ссылаться на изначальный список со старым id после присвоения self.__v[:] = self.__temp self.__v стал ссылаться на другой список, при том у него остался изначальный id за ним поменяется и v1 Получается, в результате self.__v[:] = self.__temp старый список затирается и там где он хранился в памяти возникает новый список? не понимаю логику. можно где то подробнее это разузнать?
@itsmeihope8597
@itsmeihope8597 Жыл бұрын
Если ты разобрался, объясни пожалуйста
@axe2769
@axe2769 Жыл бұрын
Это равносильно, что менять какой-либо элемент в списке, например: my_list[1,2,3,] -> my_list[0] = 12. Такая же логика и там, мы берем срез от начал и до конца, тем самым изменяем значения всего списка на значения из другого. Надеюсь понятно объяснил )
@ДімаКуріптя
@ДімаКуріптя Жыл бұрын
нет, v1 и _v ссылаются на один и тот же объект, который не затирается, а просто изменяется, потому что список это изменяемый тип данных, со строкой либо кортежем такой бы трюк не прокатил, потому что там бы в любом случае создавался новый объект, на который бы ссылался только _v
@baldman6804
@baldman6804 Жыл бұрын
Уже вроде и с ООП разобрался, декораторы, генераторы, на джанго и DRF написал несколько приложений, но вот менеджер контекста все равно вызывает у меня трудности. 😅
@Anonim-im6ln
@Anonim-im6ln Жыл бұрын
👍👍👍👍👍👍👍
@ЭльбердГодоборшев
@ЭльбердГодоборшев 2 жыл бұрын
Два дня не мог понять, почему при изменении "self.__v" меняется сам "v1", ведь нигде нет кода типа: "v1 = self.__v[:]". В итоге до меня дошло, что "v1", "v", "self.__v" это все ссылки на один и тот же список, у них у всех один и тот же id, и меняя один мы меняем все остальные.
@wasd1338
@wasd1338 Жыл бұрын
предыдущий материал курса ООП зашел на ура. но в этой теме возникла какая-то каша. 1) на 2.50 Вы пишете заголовок слайда "Менеджер контекста (with)" и вначале говорите "ключевое слово with, то есть это и есть менеджер контекста". на том же слайде на 2.50 написано, что менеджер контекста идет после ключевого слова with. так что из этого все же менеджер контекста? 2) еще больше путаницы внес первый тест после видео. один из вариантов ответа "менеджер контекста образует свою локальную область видимости (подобно функциям, тело которых находится внутри локальной области видимости)". в видео же вы создаете менеджер контекста - класс DefenderVector, далее пользуетесь экземпляром этого класса как менеджером контекста. т.е. у менеджера контекста есть своя локальная область видимости, в которой при инициализации формируется переменная self.__v. тогда почему указанный вариант ответа в тесте неправильный? исходя из того, что этот вариант ответа не верный, стоит полагать все же что менеджер контекста это with? однако для примера создания менеджера контекста вы прописываете то, что идет ПОСЛЕ with. 3) допустим, менеджер контекста - это объект после with. тогда если мы пишем with open('file') as file менеджером контекста будет open()? но ведь это же стандартная функция питона, а не менеджер контекста. Уважаемый Сергей, очень ценю Ваш труд, понимаю что материала много и грамотно его структурировать - не простая задача. в этот раз получилось как-то запутанно
@ramazanabakarov3202
@ramazanabakarov3202 Жыл бұрын
Я, конечно, не могу говорить с точной уверенностью, но как я понимаю и знаю, контекстный менеджер это то, что идет после with, ибо контекстный менеджер это класс, который содержит два магических метода __enter__ и __exit__ , а ключевое слово with существует, для того чтобы в правильном порядке вызывать данные магические методы. И как вы заметили, функция open() является по факту классом, который как раз таки и имеет эти два метода
@Antinormanisto
@Antinormanisto 6 ай бұрын
Самое непонятное видео за всё время ООП) Мой мозг не понимает ничего
@dkuz
@dkuz Жыл бұрын
Сергей, спасибо большое за видео! Я не особо понял момент на 7:35 с 11 строкой, почему там [:] у srlf.__v? Я не особо понимаю как это работает в данном случае, прошу объяснить этот момент)
@selfedu_rus
@selfedu_rus Жыл бұрын
Это база языка. Полный срез [:] для списков означает их копирование.
@dkuz
@dkuz Жыл бұрын
@@selfedu_rus я понимаю что это обозначает копирование, но я не понимаю почему это стоит у self.__v, а не у srlf.__temp. Мы же копируем __temp в __v
@selfedu_rus
@selfedu_rus Жыл бұрын
@@dkuz Внутри этой штуки: with DefenerVector(v1) as dv: мы должны работать с копией списка, т.к. если что то пойдет не так, иметь возможность его восстановить
@dkuz
@dkuz Жыл бұрын
@@selfedu_rus все, теперь понял. Спасибо большое за курс и за то, что отвечаете на комментарии, не смотря на то, что видео вышло больше года назад!
@КириллЧе-я5ы
@КириллЧе-я5ы 10 ай бұрын
Вопрос на 7й минуте - когда мы создаём enter метод, присходит переприсваивание, и таким образом копируем объект, копирование поверхностное или глубокое?.. вообще в питоне при вот таком переприсваивании какое копирование происходит?..
@selfedu_rus
@selfedu_rus 10 ай бұрын
в данном случае мы выполняем обычное копирование списка, т.е. если он будет иметь вложения, то возникнут проблемы, но это учебный пример и не усложнял
@Developer_python_
@Developer_python_ Жыл бұрын
Наверное первая тема которая до конца не ясна В частности все случаи с параметрами exit- но пока для работы достаточно и этих знаний
@ibrahimoglu
@ibrahimoglu 2 жыл бұрын
👍
@КириллЧе-я5ы
@КириллЧе-я5ы 10 ай бұрын
Для чего нужен менеджер контекста и где его применять?.. для безопасности кода и применять везде где только можно. Имхо. Потому как класс который создаёт объект и должен его уничтожать… особенно если вы работаете с ресурсами. Инициализация как захват ресурса
@dimakost9900
@dimakost9900 Жыл бұрын
Сорри, но этот урок у вас вышел очень запутанным и непонятным
@davidbibi3138
@davidbibi3138 2 ай бұрын
на самом деле нет, прост чуть знания подтяни в ООП и дандерах, там ничего страшного нет
@Cygni7
@Cygni7 Жыл бұрын
Спасибо за урок! Хочу задать вопрос, как вы выделяя несколько строк помещаете их все в комментарии (# перед всеми) или ставите перед всеми отступ (tab)? Просто когда я так делаю в pycharm, строки попросту заменяются. Это настраивается как - то? Заранее спасибо.
@selfedu_rus
@selfedu_rus Жыл бұрын
Ctrl + / (при англ раскладке клавиатуры)
@ДімаКуріптя
@ДімаКуріптя Жыл бұрын
табуляцию двигать ctrl + [, либо ctrl + ], но это для vs code, может в pycharm так же
@selfedu_rus
@selfedu_rus Жыл бұрын
@@ДімаКуріптяTab и Shift + Tab
@ДмитрийСмирнов-щ4с
@ДмитрийСмирнов-щ4с 2 жыл бұрын
подскажи пожалуйста не могу врубиться) то что мы делаем в def __enter__ когда копируем список через self.__temp = self.__v[:] понятно. а то что мы делаем в def __exit__ когда обратно копируем уже измененный список self.__v[:] = self.__temp в self.__v. что тут делает [:] непонятно(
@artbog
@artbog 2 жыл бұрын
Мы модифицируем исходный список путем присваивания срезу новых значений. Погугли.
@ДмитрийСмирнов-щ4с
@ДмитрийСмирнов-щ4с 2 жыл бұрын
@@artbog спасиб, я гуглил) но врубился только после твоей подсказки) если синтаксис b = a[:] то мы копируем все значения из одного списка и в другой (создается новые объект). Но если мы делаем так a[:] = b, том мы возвращаем срезом ту часть списка которую хотим заменить, новым списком, заменяем ее значениями на значения списка "b", а остальные оставляем, при этом ссылка на объект "a" остается неизменной.
@artbog
@artbog 2 жыл бұрын
@@ДмитрийСмирнов-щ4с все верно 👍
@genghiskhan8835
@genghiskhan8835 2 жыл бұрын
@@ДмитрийСмирнов-щ4с а есть разница между a[:] = b и a = b? Ведь в данном случае срезом является весь объект, мы ничего не обрезали.
@ДмитрийСмирнов-щ4с
@ДмитрийСмирнов-щ4с 2 жыл бұрын
@@genghiskhan8835 я понимаю так: если мы делаем a = b, то в переменную a копируем ссылку на объект из переменной b. Но если мы делаем a[:] = b то переменная a смотрит на тот же объект что и раньше (на видео это список [1, 2, 3]) и меняются сами значения в этом списке, сама ссылка на объект остается неизменной. это нам как раз и нужно по задаче, чтобы в случае успешного изменения нужный нам объект менялся, в случае неуспешного оставался неизменным. Короче разница что если сделать a = b, то в примере на видео мы в конце будем вызывать print(v1) и объект на который ссылает переменная v1 никогда не будет меняться, хоть успешно все прошло хоть нет.
@СергейФролов-ъ5я
@СергейФролов-ъ5я 2 жыл бұрын
Спасибо! Получается, что open это все таки не функция, а целый класс, где реализованы методы enter, exit, call? Т.е. мы можем в свой любой класс добавить функциональность менеджера контекста?
@selfedu_rus
@selfedu_rus 2 жыл бұрын
да в Python много что через классы сделано, например, type() тоже класс и даже метакласс, о чем подробнее дальше )
@marat_shaydulin
@marat_shaydulin Жыл бұрын
Нет, open это функция, которая возращает менеджер контекста. Вы можете сами сдеать подобную функцию: class MyContext: def __init__(self, v): self.__v = v def __enter__(self): self.__tmp = self.__v[:] return self.__tmp def __exit__(self, *exc): self.__v[:] = self.__tmp return False def give_context(v): return MyContext(v) a = [1, 2, 3] b = [2, 2] # b = [2, 2, 2] with give_context(a) as v: for i in range(len(v)): v[i] += b[i] print(a)
@КаримКеримков
@КаримКеримков 10 ай бұрын
в UI библиотеке Gradio очень непонятное использование менеджера контекста import gradio as gr with gr.Blocks() as demo: gr.Markdown("...") with gr.Tab("Flip Text"): gr.Markdown("...") demo.launch() Не понятно как это работает)
@gore_ot_uma166
@gore_ot_uma166 2 жыл бұрын
Я правильно понимаю, что именно слово with определяет порядок вызова и делает сам вызов методов __enter__, __exit__ ? потому как код dv = DefendVector(v1)... не работает, хотя методы в классе переопределены
@selfedu_rus
@selfedu_rus 2 жыл бұрын
да, менеджер контекста сам вызывает эти магические методы
@Алекс21-р8р
@Алекс21-р8р 2 жыл бұрын
Круто! Вы где учились?
@selfedu_rus
@selfedu_rus 2 жыл бұрын
Спасибо! Просто давно программирую и преподаю в вузе (детали не спрашивайте, не люблю публичность)
@Keshtiman
@Keshtiman 2 жыл бұрын
@@selfedu_rus при этом фамилию свою сказали))
@ИльдарВасиков-я3р
@ИльдарВасиков-я3р 2 жыл бұрын
Добрый день! Спасибо большое за все Ваши уроки. Они очень полезны. Хотел спросить а по ООП в Python не планируется ли курс на Stepik?
@selfedu_rus
@selfedu_rus 2 жыл бұрын
пока не знаю, сейчас явно не до этого
@Alex_Gor_1
@Alex_Gor_1 Жыл бұрын
Взял и купил курс от поколения, уперся в задачу и не могу решить. Посмотрел видеоурок от Балакирева - понял что делал не так. Покупка была ошибкой.
@КириллЧе-я5ы
@КириллЧе-я5ы 10 ай бұрын
Ошибку поправьте или меня - имя переменной мен контекста полагаю должно быть fp, а не f… (2-я минута)
@selfedu_rus
@selfedu_rus 10 ай бұрын
да, очевидная ошибка, за всем не уследишь, на мой взгляд настолько очевидно, что даже не менял
@КириллЧе-я5ы
@КириллЧе-я5ы 10 ай бұрын
@@selfedu_rus зато ролик отличный, спасибо!
@radceb2474
@radceb2474 2 жыл бұрын
👍
This dad wins Halloween! 🎃💀
01:00
Justin Flom
Рет қаралды 68 МЛН
Человек паук уже не тот
00:32
Miracle
Рет қаралды 3,9 МЛН
They Chose Kindness Over Abuse in Their Team #shorts
00:20
I migliori trucchetti di Fabiosa
Рет қаралды 11 МЛН
КОНТЕКСТНЫЙ МЕНЕДЖЕР(WITH) PYTHON
17:46
Андрей Иванов | Python
Рет қаралды 6 М.
Магические методы в python. Dunder методы
1:00:45
PYTHON МАГИЧЕСКИЕ МЕТОДЫ: __STR__ + __REPR__
8:33
Контекстные менеджеры в Python
6:26
Evrone Development
Рет қаралды 446
This dad wins Halloween! 🎃💀
01:00
Justin Flom
Рет қаралды 68 МЛН