Мой курс «Хардкорная веб-разработка» - course.to.digital Вжух!
@ruslan5773 жыл бұрын
Сегодня закончил проходить один неплохой курс по Django, чтобы реализовать свой петпроджект. Сел за "чистый лист" и понял, что понятия не имею, как правильно организовать архитектуру приложения с учетом обработки бизнес-логики. Почему-то этот вопрос в курсе обойден стороной (а точнее там все зафигачили во вьюху). Посмотрел твое видео - и в голове все встало на свои места. Большое спасибо, очень ценно!
@normaneye51873 жыл бұрын
Что за курс закончил? Поделись названием
@ДанилКропива2 жыл бұрын
@@normaneye5187 Гоша Дударь
@apostol_fet2 жыл бұрын
Обычно вроде как в модели все советуют выносить, но ао вьюху, это конечно прикол
@data19101988 Жыл бұрын
Тоже курсы прохожу, уже пошла рефакторить😂
@bizdinvideo Жыл бұрын
смотри в сторону паттернов. Типа Репозитории Dry.... Когда нужно использовать и когда не нужно. Паттерны написаны кровью и пОтом разрабов, рекомендую. После изучения паттернов поймешь что джанго это то еще говно с коробки.
@DmytroFrame4 жыл бұрын
Код на 4К телевизоре шикарен! Спасибо что выпускаешь видео в 4К.
@brokenleg61224 жыл бұрын
Мне, как новичку в Django и вебе вообще, это видео просто чертовски полезно. Спасибо вам большое и удачи в развитии канала
@t0digital4 жыл бұрын
Отлично, рад, что полезно!
@MadMike934 жыл бұрын
Правильно нарвался на видос)) не будешь совершать наших новичковских ошибок)) Вот сейчас решил глянуть на свой старый проект, а там одна вьюшка на 285 строк кода, другая на 176))) не надо так))
@VideosfromMariupol Жыл бұрын
Как успехи за 3 года? Устроился?
@Kirill-rg8vj4 жыл бұрын
Вот это реально сейчас пригодилось , ибо начал переписывать старый проект и после просмотра понял , что допустил кучу ошибок даже в новой версии, спасибо , очень помогло
@kannykl75754 жыл бұрын
Контент просто золото, спасибо за ваш труд!Верю, что справедливость восторжествует, и этот канал станет миллиоником!
@t0digital4 жыл бұрын
Идём к этому:) Спасибо!
@tsarevnalagushka4 жыл бұрын
Очень приятно посмотреть, как прямые руки код пишут. И, надеюсь, полезно
@t0digital4 жыл бұрын
Спасибо! Тоже хочется верить, что полезно:)
@no_name_19144 жыл бұрын
Диджитализируй: *выпускает видео* Я: *ставлю лайк и иду рефакторить*
@t0digital4 жыл бұрын
Рад, что полезно!
@sidorovich211019864 жыл бұрын
В PyCharm используй Shift+F6 для переименования функций и классов. Иначе при частых переименованиях очень легко поломать код в каком-то месте, просто, потому что забыл там переименовать (и даже об этом знать не будешь). А заодно расскажи про это новичкам. Это будет очень полезный для них совет.
@ayhan_web_developer8 ай бұрын
Здравствуйте, спасибо большое за видео ролик, вы очень хорошо объяснили как правильно делать и мне как новичок в Back-end разработке очень было понятно и полезно, ещё раз спасибо 🙏
@life8261 Жыл бұрын
Отличное видео. Очень жалею, что не посмотрел его раньше, потому что мне пришлось до концепции отделения бизнес-логики доходить самому очень кровавым и долгим путем. А тут бац: и всё готовое, пользуйся на здоровье. Спасибо вам огромное за ваш труд! Однозначно лайк :).
@cronosnoname40384 жыл бұрын
Лёха - это просто бомба, спасибо тебе большое ! Формат огонь, кратко\четко\все понятно и по делу, требую продолжения )
@t0digital4 жыл бұрын
Спасибооо!
@romangredis37223 жыл бұрын
Сразу видно, пользователя Виндоус)
@bogdanvolodko11194 жыл бұрын
Каеф. Если будет не сложно, хотелось бы увидеть каноничный REST API на Django rest framework. Спасибо :3
@t0digital4 жыл бұрын
Спасибо! Возможно запилю:)
@olegmlavets52164 жыл бұрын
Тоже очень интересно
@ultixn4 жыл бұрын
Во во точняк!!!
@MrDnovik4 жыл бұрын
@@t0digital тоже бы посмотрел
@serhiyprots85864 жыл бұрын
Было бы очень интересно
@olegssh64524 жыл бұрын
Круто что есть профессиональные разработчики, передающие свой многолетний опыт в такой понятной форме!
@MrOnlineCoder4 жыл бұрын
Видео отличное, из серии "ответы на вопросы, которые вы боялись спросить")) Но буду рад услышать совет - я, к сожалению, не питонист, а node.jsник, но принципы там очень схожи. Так вот: 1) У тебя бизнес логика для рассылок жестко привязана к mailchimp. А что если завтра прийдеться перейти на другой сервис рассылок? Везде рефакторить импорт и названия? Хоть я и не верю что наступит это "завтра", но в общем случае рекомендуют создавать интерфейс по типу IEmailService, и чтобы mailchimp сервис реализовывал его. Вопрос: что с этим делать, и как вы реализовываете это в питоне? 2) Могут ли сервисы импортировать другие сервисы? Ответ скорее всего да, но как в таком случае тестировать отдельные сервисы? Обычно применяют dependency injection, но можно ли без него обойтись? Заранее спасибо.
@РоманКирин-с2ю4 жыл бұрын
Приветствую! Для начала хотел поблагодарить за контент и выразить свою признательность за тот вклад, который Алексей делает в сфере популяризации и развития индустрии. Мне одному кажется, что в последнее время очень много внимания уделяется комментированию и именованию переменных, совсем позабыв о значимости методик моделирования и интерпретации кода как такового. Нет, я не говорю, что комментировать код не нужно, - нужно!!! и причем обязательно. В последнее время, лично у меня, сложилось ощущение, что все аля тимЛиды и сеньёры сговорились, пытаясь навязать мнимые ценности джунам, маскируя облегчение собственноручного код ревью, под «Паттерны комментирования». А теперь внесу свои пару капель дегтя в бочку меда: 1. GET запросами оформлять почтовые подписки? Серьезно? 2. По сути задачи 2 представления можно было бы отменить в 1, тем самым, применение DRY выглядело бы поубедительнее. Выделяя case_id = None(общие подписки) мы можем ограничиться одной моделью и одним представлением, тем самым «развязывая себе руки» для более высокоуровневого манипулирования сущностями. 3. Django.forms на мой взгляд решает все те проблемы, которые были размазаны между views.py(валидация) и services.py(логика) … Хотя тут уже больше вопрос вкусовщины… 4. CBV… Всегда стараюсь отдать предпочтения именно им, только если не стоит вопрос производительности. Но на таких задачах только они. Как отработает представление, если запрос будет POST,PUT? Что будет, если для каждой передаваемой переменной нужно удалить пробелы? Ну и тд…. 5. Settings.py Ну если мы бьемся за минимизацию количества строк в файле, то мб переменные mailcamp вынести в отдельный файл(аля mailcamp_settings.py), а в settings.py сделать импорт? 6. Настоятельно не рекомендую делать запросы к сторонним сервисам в рамках синхронного запроса. Это вешает сервис….причем как правило каскад сервисов… Но это уже другая история.. Алексей еще раз благодарю за контент!! Делать познавательные видео, гораздо полезнее и познавательнее, чем писать критикующие каменты!
@t0digital4 жыл бұрын
Спасибо за развернутый комментарий! > GET запросами оформлять почтовые подписки? Серьезно? Вьюшка из видео обработает и POST запрос, но мейл в данном случае передан в GET параметре, да. Я не считаю, что жёсткое следование REST в этом конкретном примере столь важно. > По сути задачи 2 представления можно было бы отменить в 1 Можно, но я не сказал бы, что две эти задачи настолько схожи, что имеет смысл объединить их в одну вьюшку. Подписки на разные сущности вполне подвержены потенциально разной логике обработки (как минимум будет проверка наличия Case, в будущем может появиться еще что-то, например, проверка авторов, относящихся к Case, и навешивание отдельных тегов в Mailchimp подписывающемуся). Если у нас 2 вьюшки - разный код будет в разных вьюшках, если у нас 1 вюьшка - то в ней неминуемо будут появляться куча if ветвлений, что усложнит логику, усложнит чтение и поддержку кода. Помимо DRY есть еще KISS:) Возможно я бы сделал CBV с наследованием, но опять же не уверен, что это здесь оправдано. > Django.forms на мой взгляд решает все те проблемы Я не считаю правильным использовать формы для чего-то, выходящего за рамки работы с формами. > CBV… Всегда стараюсь отдать предпочтения именно им Нормально, почему нет. Я тоже люблю CBV, как раз туда проверку исключений добавить в базовый класс и тд. > settings.py Можно, но выносить несколько строк кода в отдельный файл не уверен, что оправдано. Если конфигов прям много-много, тогда да. Но на практике такого не видел, чтобы конфигов в одном settings.py было столь много, чтобы это перестало быть комфортным. > Настоятельно не рекомендую делать запросы к сторонним сервисам в рамках синхронного запроса Да, конечно, тем более в синхронной джанге. Но это действительно другая история, не про БЛ. Спасибо:)!
@РоманКирин-с2ю4 жыл бұрын
Диджитализируй! Спасибо за ответ!) Я не придерживаюсь позиции rest, тут какбы позиция реализации http: если основной результат выполнения запроса запись в хранилище, то post исправление put и тд. Эти рекомендации были задолго до появления rest. «Нет ничего более постоянного, чем временное» и «проект нельзя закончить, это как ремонт в своей квартире: можно только остановить»
@digital_ninja4 жыл бұрын
Спасибо огромное. Новые проекты делаю с файлом services в app'ах.
@tandinio4 жыл бұрын
Спасибо вам огромное за полезные ролики. Недавно начал вас смотреть(являюсь junior full-stack developer-ом). Написал свой интернет-магазин, но после просмотра последних 2х видео про бизнес-логику, осознал, насколько неправильно подошел к данному вопросу(тупо копировал код из одной вьюшки в другую). Открываете глаза на программирование в целом. Спасибо огромное! C нетерпением жду выпуска следующих видосов:)
@iamlobstarr3 жыл бұрын
Супер! Спасибо огромное. Прошёл курс по джанге, где всю логику делали во вьюхах, спрашивал препода, как улучшить код, он отвечал, что долгая история, пока не доросли. Тут же за час времени все как по полочкам разложено. 👍🏻
@ДанилЕфимов-г9п Жыл бұрын
Сколько полезной информации на вашем канале я получил не сосчитать, а сколько еще осталось). Спасибо за труд, все стало на свои места после вашего наглядного примера. Всех благ!🔥
@t0digital Жыл бұрын
Отлично, рад, что полезно!
@мрхбублик4 ай бұрын
Не подскажешь? А файл mailchimp_services не нарушает принцип независимости приложений? Написан в одном приложении, другое его импортирует. Это считается нормальной практикой? Или в будущем нужно будет это исправить? Например, засунуть его в корневой каталог ( там где находится файл settings)
@div39753 жыл бұрын
Отлично! Помогло разрешить ряд вопросов, которые бродили в голове.
@serhio24414 жыл бұрын
Отличный выпуск! Как впрочем и всегда) Очень правильный подход показать как сделать плохо и поэтапно указать на ошибки и способы их исправить, соответственно и рефакторинг кода. Ещё раз подчеркивает важность не торопиться и не забивать так же на проектирование и продумывание логики, а не кидаться сразу в код и что-то писать... В общем, выпуск супер!
@rinatyagafarov5328 Жыл бұрын
Третий или четвертый раз смотрю это видео. И только сейчас словил инсайт про хранение паролей в переменных окружения. Это же очень удобно, и не нужно париться, что конфиг с паролями улетит в репозиторий. Прям душевно благодарю за видео 🔥🔥🔥🔥🔥
@t0digital Жыл бұрын
Отлично:)!
@vitaliyboychenko68824 жыл бұрын
Лучший контент по пайтону на ру ютубе, лайк!
@t0digital4 жыл бұрын
Спасибо!
@happypanda19954 жыл бұрын
Спасибо большое! Наконец-то дождались :)
@anuwaygamechannel322511 ай бұрын
Как сказал один известный человек. Круто да этож круто. Получил для себя новый глоток для размышлений над улучшением своего проекта)
@justborney2 жыл бұрын
Алексей, спасибо! Это как раз то, что мне было нужно
@vladislavmikhailov2 жыл бұрын
Круто! Очень полезно, прям больше понимания стало! Хоть только начинаю Django мучить, но теперь есть понимание как реализовывать проекты!
@i8enn4 жыл бұрын
Отличный выпуск! Хорошо все рассказал и показал - красавчик! Получился неплохой пример написания кода. Причем есть даже такая практика - сначала пишем как попало (если не можем определиться с архитектурой и структурой на "берегу"), а потом рефакторим, чтобы не делать "равиолли-код" и избежать "оверинженеринга" (правда, это скорее для новичков - у опытных разработчиков почти все получается сразу). P.S.: Но опыт не пропьешь - написать вьюшку начинающего junior-а не получилось (всеравно чувствуются хорошие привычки) ;). Я обычно не пишу комментарии, а сейчас отвлекся и вместо того, чтобы дописать сообщение к коммиту - пишу комментарий ;) Ещё правда есть пару вопросов, не обессуть ;) Disclaimer: цель данного комментария узнать мнения автора видео. Он не имеет задачи задеть чьи-либо религиозные чувства (в том числе в нейминге) и породить священную войну в ответах под собой. Автор комментария так же не является "троллем" и просто хочет узнать мнения автора видео. 1. Почему services, а не logic? Я понимаю, вкусовщина, но просто интересно твое мнение. У меня при виде services сразу в мыслях, что там код какого-то сервиса, а не бизнес-логика пакета. Хотя я бы положил работу с клиентом mailchamp (mailchamps_services) куда-нибудь в utils. Причем, можно даже на уровне проекта, а не приложения - так оно будет доступно для всех пакетов, если понадобится. Уж очень это похоже на шорткаты. Хотя кто-то говорит, что utils - это зло, потому что мы складываем туда все, что неможем отнести к какому-то модулю. Логику самого приложения (services.py у тебя) я бы закинул в logic.py (но тут просто различие в названии). Вообще правильный нейминг это холиварная тема (правда тут у каждого своя - главное, чтобы было понятно), поэтому можешь не отвечать ;). P.S.: Зря, зря я написал этот вопрос, но дюже интересно узнать твое мнение. 2. Как ты относишься к логике в django-rest-framework (DRF) фильтрах и сериализерах если речь идет не о логике сериализации/фильтрации? Ну самое элементарное это методы create/update в сериализерах DRF, вместо вызова функций логики сохранения (простой или сложной) непосредственно во view функции? P.P.S.: Жирноватый комментарий получился, спасибо всем кто дочитал до конца и прошу прощения за потраченное время и ресур вашего зрения ;). Ещё раз повторюсь, что нехочу никого обидеть (особенно автора видео) и если так получилось, то за это тоже прошу прощения. Так же прошу прощения за переход с автором видео на "ты" без его разрешения. Но проще просить прощения, чем разрешения (Zen Python) - так что можно бросить в меня Exception ;) И ещё раз хочу сказать спасибо за видео и за канал в целом. Для новичков (да и не только) это очень полезный формат, потому что увидеть как опытные разработчики программируют и мыслят мало где можно. Есть, конечно github, но в хороших проектах с хорошим кодом новичку будет трудно разбираться и понимать мотивацию, а здесь все доступно, понятно и с комментариями (как говорится то, чему не учат в школе и даже в университете ;)). Ещё раз спасибо - продолжай в том же духе, ты делаешь полезное дело!
@trytoStopTV4 жыл бұрын
Это что за такое осмысление Python Zen про "просить прощение"? :D Поделитесь источником, будьте добры.
@i8enn4 жыл бұрын
@@trytoStopTV Здравствуйте! Вы задали очень интересный вопрос, и чтобы на него ответить я ещё раз открыл PEP 20 в поисках "Easier to ask for forgiveness than permission" и.... не нашел. Для меня это было странно, я так привык к этому принципу, который для меня казался не отделимым от Python, что начал пытаться вспомнить, где я его видел. Через пару минут до меня дошло, когда я нашел его упоминание в "глоссарии" python - это принцип EAFP. Рука - лицо. Стыдно. Но теперь выпавшее звено встало на свое место. А Вам хочу сказать спасибо - теперь не буду ссылаться на Zen упоминая эту фразу (конечно, если опять не забуду, что это перевод расшифровки EAFP принципа...).
@anatolys92034 жыл бұрын
Супер! Ну как всегда собственно))) спасибо большое за твой труд!
@turtlechevalry4 жыл бұрын
Я интуитивно пришёл к тому же, только осмыслить был не в состоянии. Казалось, что я просто отсебятину делаю и просто плохо усвоил джангу. А оказалось, все правильно. Респект. Все понятно. Термин services возьму на вооружение
@pixel71394 жыл бұрын
а будет тематика о тестировании? интересно было бы послушать, unittest, pytest, best practice всяких теорий полно, а практики совсем мало, особенно что касаемо Джанго API
@t0digital4 жыл бұрын
Думаю, о тестировании будет материал, да!
@MadMike934 жыл бұрын
Поддерживаю. Я тоже вкурить не могу пока как тесты писать.
@nikkie_cold Жыл бұрын
Ну так будет или нет? =)
@meta34794 жыл бұрын
Алексей, просто СПАСИБО тебе! Лучший канал по питону.
@t0digital4 жыл бұрын
Спасибооо!
@scadeline8054 жыл бұрын
Отличный ролик и отличный канал! Респект. Работаю бэкендером на Django, и ваши ролики помогают развиваться. Спасибо
@t0digital4 жыл бұрын
Спасибо! Рад, что полезно
@inspayran2049 Жыл бұрын
Благодарю за видео) узнал много полезного) Да и подача хорошая, не было скучно слушать часовой ролик)
@SergeyMenshov3 жыл бұрын
Большое спасибо вам, за науку! 👍 Сегодня не поленился и применил такую же логику на одном своем проекте на Lumen (PHP), реально стало гораздо удобнее. Теперь смотрю на очищенный от бизнес логики контролер и аж глаза радуются. 😀
@t0digital3 жыл бұрын
Отлично! Всё правильно, применимо на любой технологии:)
@vladimirezh4 жыл бұрын
Приятно смотреть на человека, который понимает что он делает и хорошо владеет инструментом(языком программирования). Пишу на .net, но код читался, как песня.
@PythonDevelopment4 жыл бұрын
Привез лайкосиков, куда разгружать, командир? =)
@t0digital4 жыл бұрын
О, разгружаем здесь!
@yakoro4ka1124 жыл бұрын
Полезность канала растет на глазах! Живой кодинг - это маст хэв)
@t0digital4 жыл бұрын
Йеее:) Спасибо!
@ВолодимирВдовин4 жыл бұрын
Помню в одних из первых видео у вас дублировалось на экран все символы которые вы печатали, для меня это было очень полезно так как я стараюсь полноценно научиться пользоваться vim'ом. Было бы очень круто если бы во всех видео с практикой было такое отображение.
@govdamikhaylo41834 жыл бұрын
Вот видос который меняет взгляд на жизнь:)
@exemplles2 жыл бұрын
Самое полезное видео по Джанге. Thx
@nikitabalaganskiy62574 жыл бұрын
Огромное спасибо за контент!
@maksim43344 жыл бұрын
Да. Пожалуй нужно подписаться и поставить лайк. А ведь он говорил вам, не используйте time.time, еще тогда надо было задуматься.
@fedyasam17003 жыл бұрын
Супер. Обожаю ваши труды)) респект
@ЕвгенийГригорьев-ж5з3 жыл бұрын
Спасибо за урок сансей) пойду заварю чай и отрефакторю свой код полностью)
@misterX3894 жыл бұрын
Офигенный мастер-класс. Спасибо.
@tsarevnalagushka4 жыл бұрын
Было бы интересно посмотреть review какого-нибудь opensource проекта на django
@t0digital4 жыл бұрын
Интересная идея, спасибо!
@MrDnovik4 жыл бұрын
Спасибо большое, очень полезное видео.
@StoGigovo4 жыл бұрын
Отличное видео, просмотрел все. Вынес много интересного.
@t0digital4 жыл бұрын
Рад, что полезно!
@StoGigovo4 жыл бұрын
@@t0digital Сразу пошел смотреть на свои проекты, и как истинный Джун, я там налажал, все как в видео ) Исправлять начал, такая красота стала а!) Даешь больше видео по Питону!)
@gaminggamer6860gaming4 жыл бұрын
Спасибо за видос! Было бы круто увидеть видео в таком же формате по обработке исключений и логгингу
@t0digital4 жыл бұрын
Сегодня будет видео про переменные окружения, и скоро будет и по исключениям, логированию.
@timur82164 жыл бұрын
Красавчик! Больше таких видео!
@t0digital4 жыл бұрын
Будет еще много хороших видео:)!
@m0rtym0rty74 жыл бұрын
только вот задавался вопросом о бизнес логике сегодня. Много перерыл, так и не понял, и вот ты, кайф. Мне везет)
@t0digital4 жыл бұрын
Отлично:)!
@gustaugutter94774 жыл бұрын
Офигеть, ты все таки его сделал)) Спасибо большое, гляну обязательно) Лайк не глядя)
@t0digital4 жыл бұрын
Юхууу, спасибо!
@exorciste20074 жыл бұрын
Для функций которые прям ничего не возвращают есть клёвая штука в typing модуле - это NoReturn. Наверное её использование более логично в данном случае. Благодарю за видео, годный контент делаешь! Лайк
@daninspace9009 Жыл бұрын
Это только для функций которые именно что не завершаются, например в которых бесконечный цикл. Если функция всё же нормально завершается и ничего не возвращает, то необходимо использовать None
@Bandera_tut4 жыл бұрын
Круто, также делал в фласке, думал что сильно умно. Замути еще, пожалуйста, про переменные окружения, правильную настройку файла settings.py перед первым коммитом.
@MadMike934 жыл бұрын
Поддерживаю)) и ещё бы хотелось услышать про альтернативы переменным окружения в виде Ansible, или Zookeper))
@justjohn98324 жыл бұрын
Вот это как раз мега-полезный выпуск, очень в тему к тому, что я сейчас делаю
@t0digital4 жыл бұрын
Отлично, рад, что полезно
@АлександрИванов-ъ7р6ч2 жыл бұрын
Спасибо, интересно и познавательно!
@oleksandermrychko57674 жыл бұрын
Спасибо что делитесь опытом. Я подумал возможно Вам будет интересно осветить тему контроллеров-классов и контроллеров-функций. А именно в каких ситуациях одно эффективней другого либо наоборот. Спасибо.
@t0digital4 жыл бұрын
Классы удобны для переиспользования какой-то контроллерной логики, для всех остальных случаев обычно хватает контроллеров-функций
@Flint3673 жыл бұрын
В принципе ничего нового я тут увидеть не ожидал, но какое же черт возьми удовольствие приносит лицезрение распиливания лапши)
@microsoft87922 жыл бұрын
Отличное объяснение!
@t0digital2 жыл бұрын
Спасибо!
@juzzie8184 жыл бұрын
спасибо огромное за все, что делаешь и за этот мастер-класс в частности)
@tilekasankulov50344 жыл бұрын
Шикарный видос. Подача очень крутая! Может сделаете серия мастер классов по django?)
@t0digital4 жыл бұрын
Спасибо! Может быть сделаю
@gromovoy19874 жыл бұрын
Отлично! Можно и нужно всё-таки исследовать exceptions и что-то с ними делать. Не все всегда будет работать гладко думаю
@t0digital4 жыл бұрын
Да, по исключениям были недавно видео на канале, и по их обработке в middleware джанги
@gromovoy19874 жыл бұрын
@@t0digital Посмотрю, спасибо
@arkadyaeternit97934 жыл бұрын
Отличный выпуск, как всегда огромное Спасибо! Было бы неплохо еще посмотреть про логирование, как неотъемлемое составляющее проекта в продакшн.
@t0digital4 жыл бұрын
Будет такое видео
@arkadyaeternit97934 жыл бұрын
@@t0digital Очень хорошо, буду ждать!
@Im_Seth11 ай бұрын
Здравствуйте, расскажите пожалуйста про вашу настройку ide (понравилась подсветка django файлов в левом сайдбаре)
@GROGA654 жыл бұрын
Долгожданное видео ))))
@t0digital4 жыл бұрын
Йееее!
@egorkomarov47194 жыл бұрын
Мне понравилось - очень полезная информация
@t0digital4 жыл бұрын
Спасибо!
@velomatica4 жыл бұрын
Ну здесь мои полномочия всё...Здесь питоний дух, Питоном пахнет )))
@t0digital4 жыл бұрын
Хахах:) Полномочия всё!
@donfedor0072 жыл бұрын
В классах используются миксины для создания данных в бд из форм например, это помути обработку бизнес логики мы делегируем классу миксину?
@ashm_tech Жыл бұрын
Здравствуйте, Алексей!) А не думали ли вы о выпуске обновления данного видео, с новыми технологиями, и тд
@deve1oper2 жыл бұрын
Подскажите пожалуйста, а как быть, если во вьюхе все на базовых классах написано? как правильно организовать успешную работу этого всего? Можно ли в services.py создать класс и просто унаследоваться от него во вьюхе и просто использовать его методы, или надо каждый раз получать экземпляр класса и с ним уже работать?
@dmitry646320 күн бұрын
Отличное видео, вот только тут не упомянуто про сериализаторы, ведь если брать ModelSerializer, то он сразу может сохранить объект (и это бизнес-логика) или его лучше не использовать? А использовать обычный Serializer для валидации данных и все? и внутри сериализатора доп. валидацию можно прописывать или это нежелательно?
@dmitrytsmyh59714 жыл бұрын
Полезное видео! Одно замечание: выносить код, связанный с БД в отдельный файл есть ли хорошая идея? Каждая вьюшка, класс или функция, связана с роутером. Она или дает инфу из БД, либо ее ложит туда. Придется ради одной-двух строк писать ненужные функции и засовывать их, куда не найдешь потом.
@victortamanov4 жыл бұрын
Огромное Спасибо!!! Теперь понятно, как рефакторить длинный код! Можно ли по возможности рассказать о том, как писать по TDD принципу? И как рефакторить имеющийся код по TDD, если такой подход для этого вообще применим? Если применить TDD к этому примеру после того, как написан "новичковый" код, пришлось бы переписывать кучу тестов. Или пришлось бы "гонять" структуру кода в голове до тех пор, пока не сформируется первый правильный тест. А как делать по best practice?
@ЭдуардБеженов-д3ь Жыл бұрын
Вот где вим брал свое начало)
@darkside24364 жыл бұрын
Топ контент по джанго
@t0digital4 жыл бұрын
Спасибо!
@wordpreslabs4 жыл бұрын
Как насчёт ролика по лайфхакам конфигурации django, переменные окружения, контейнеры, алиасы) ну как ты любишь)
@swimmwatch4 жыл бұрын
Спасибо за видос. Хотелось бы ещё видос по DRF. Очень классно наблюдать за тем, как пишет профи. У меня вопрос: мы очень часто создаём mailchimp client. Можно ли его как-то вынести в singleton? Чтобы у нас был один экземпляр клиента.
@slenchannel19474 жыл бұрын
Отлично рассказываешь! Кратко, ясно и по делу. Не планируешь ли серию уроков по Django?
@t0digital4 жыл бұрын
Я пишу сейчас большой курс по веб-разработке на Python, он будет
@slenchannel19474 жыл бұрын
@@t0digital Балдеееж. Аж настроение поднялось хы
@fakefakekovich42574 жыл бұрын
@@t0digital курс будет платным?
@icherniakov4 жыл бұрын
Диджитализируй! Привет! А в нем будет DRF и какой-нить JS фреймворк?
@t0digital4 жыл бұрын
курс будет платным
@YagubGuseynov5 ай бұрын
Можно было бы сократить видео до слов "Надо создавать функции и выводить их в отдельный файл"
@t0digital5 ай бұрын
Могу сократить еще сильнее: надо
@vlaih04 жыл бұрын
Очень классное видео!
@t0digital4 жыл бұрын
Спасибооо!
@eduardmart123711 ай бұрын
А как сделать этот mailchimp асинхронными?
@PrefixKrema4 жыл бұрын
Правильно ли я понимаю, что вы создали фабрику которая возвращает обьект мейлчипа. Но при этом каждый раз создается новый объект, и аутентификация по кредам к апи. То есть во всех местах где мы вызываем эту фабрику мы спамим обьектами в память и дудусим сервер? Стоит ли в этой задаче делать ленивую фабрику, с синглтоном, и использовать один обьект? Спрашиваю потому что натыкаюсь на менние что синглтон это антипатерн, ну и вообще применим ли такой подход конкретно сейчас. Спасибо.
@CooleR1524 жыл бұрын
Алексей, курс какой-нить планируется у тебя? Проводишь ли индивидуальные занятия?
@alexeyshapka4 жыл бұрын
Было бы круто ещё ссылочки на гитхаб репу!
@BorisenkoV892 жыл бұрын
Добрый день, будет ли курс по FastApi?
@romanbush51642 жыл бұрын
Почему не использовал валидацию? куда её писать и разве такой подход лучше чем использование rest классов?
@surelyy24004 жыл бұрын
Отличное видео
@t0digital4 жыл бұрын
Спасибо!
@serhii-6664 жыл бұрын
Как насчет устранения жестких зависимостей от баз данных и самого Джанго? В стиле Чистой архитектуры. Вот это было бы интересно.
@alexkanunnikov49082 жыл бұрын
А если поговорить про Django REST framework с его сериализаторами. То куда их? Также в сервисе использовать или всё-таки выносить использование сервисов в сам сериализатор? Подскажете?
@андрейхоменко-и5я2 жыл бұрын
Что можно сказать... Необходимо было данный урок посмотреть два года назад... Что бы сегодня небыло так больно, прийдя к осознанию того, что можно было всё это знать заранее, а не приходить к аналогичному мнению пройдя по тысячи грабель...
@sergeyretivykh75914 жыл бұрын
Много по существу, интересно услышать комментарии на такие вопросы: 1. mailchimp_services.py со временем резонно переедет в /services/mailchimp.py, где рядом будут все другие внешние апи и интеграции. Не будет путаницы этих services и services внутри app? 2. Как по мне, название add_email_to_common_mailchimp_list не говорит о том, что будет идти запись каких-то данных в базу, помимо обращения к только mailchimp. 3. _get_mailchimp_service тут вызывается каждый раз дважды, почему бы не объявить глобально клиент в начале файла и юзать его готовый? 4. Запросы к базе и обработка результатов нормально уживаются внутри app/services.py или бывает необходимость разделить это в дальнейшем тоже на 2 отдельных слоя?
@t0digital4 жыл бұрын
1. Либо services.py, либо папка=пакет /services/ с файлами=модулями внутри. В целом не проблема обычно начать с services.py модуля и заменить его впоследствии на пакет с несколькими модулями. 2. Согласен, это не очень хорошо. Есть поведение, которое по названию функции не подразумевается. Надо переименовать и/или побить функцию на несколько (уже не помню детали по видео) 3. Глобально в начале файла я бы это не создавал, в целом можно обернуть это всё в класс и создавать в нём один экземпляр или синглтон сделать, или просто в _get_mailchimp_service реализовать кеширование созданного экземпляра. Есть куда улучшать, всего в одном видео не показать, да и улучшение процесс в общем бесконечный, если есть время на него 4. Думаю, что зависит от задачи. Что-то простое уживётся, что-то сложное точно надо будет побить на 2 или больше слоев в зависимости уже от бизнес-логики. Мыслите верно:)
@user-xz5oz Жыл бұрын
А можно ссылку на гит, где этот код представлен. Заранее спасибо
@t0digital Жыл бұрын
Не выкладывал его
@dimak45284 жыл бұрын
Все круто, полезно. Только как тестировать ф-ии, использующие mailchimp? Фейковую апи mailchimp подсовывать или как?
@sivr5vs384 жыл бұрын
Dima K4 тут только манкипатч поможет
@m0ntecr1st044 жыл бұрын
Моки
@АндрейКулагин-е1ш Жыл бұрын
Спасибо большое за видос, было очень полезно. Не нашел у вас похожего видео про DRF. Его нет?
@t0digital Жыл бұрын
его нет
@MrDimka121014 жыл бұрын
Больше годных практик богу годных практик)
@dmytrokorbanytskyi15864 жыл бұрын
Спасибо за видео, было интересно. Можете пожалуйста показать архитектуру приложения, где также есть ClassBasedViews: они несколько нарушают принципы данного подхода, интересно увидеть, как это можно красиво сочетать.
@vkh58643 жыл бұрын
Премного благодарен!
@evgenykondratyev97704 жыл бұрын
А как в таком случае должна проходить валидация данных? Она же по идее должна быть в сериализаторах/формах, но при этом, если мы будем тестировать бизнес логику, то валидация данных будет и внутри "services"? Например, минимальная длина имени пользователя - 5 символов. Если с фронтэнда приходят невалидные данные, сериализатор заругается. А как быть при тестировании? Ведь когда мы тестируем бизнес логику, данные через сериализаторы не проходят)