Асинхронная SqlAlchemy | База Данных в Telegram боте на aiogram 3 #7 Middleware слои, CallbackQuery

  Переглядів 17,297

Python Hub Studio

Python Hub Studio

День тому

В этом видео, по созданию Телеграм бота на python с aiogram 3, будем работать асинхронно с базой данных postgresql и sqlite через ORM систему SqlAlchemy, познакомимся с middleware слоями в aiogram 3, а также с Inline кнопками и клавиатурами и событием callback query.
00:00 Обзор кода Телеграм бота на aiogram 3 с прошлого видео
02:40 Middleware слои в aiogram 3
14:53 Работа с базой данных. Установка sqlalchemy, asyncpg и aiosqlite
17:51 Создание / описание моделей (таблиц) в sqlalchemy
26:30 Создание асинхронного engine и менеджера сессий sqlalchemy
35:56 Передача сессий orm sqlalchemy через middleware слой в хендлер aiogram бота
39:02 Добавление товара в таблицу базы данных
47:29 Удаление товара из таблицы
53:32 Отправка изображений ботом
56:29 Инлайн клавиатуры и кнопки в aiogram 3
01:04:14 Событие Callback Query
01:10:06 Изменение товара в БД. Модифицируем FSM на добавление/изменение товара
01:23:06 Установка PostgreSQL сервера на ПК
01:26:32 Создание базы данных в PostgreSQL и создание нового пользователя
01:33:04 Подключение бота на работу с PostgreSQL
01:36:06 Финальные тесты
Поддержать канал:
На канале доступна функция Спонсорство с дополнительными бонусами.
Присоединиться:
/ pythonhubstudio
А также кнопка Суперспасибо под видео (отображается не во всех странах).
Документация API Telegram:
core.telegram.org/api
Документация aiogram:
docs.aiogram.dev/en/latest/
Код из видео:
github.com/PythonHubStudio/ai...
Этот плейлист:
• Telegram бот на python...
Настройка VS Code как у меня:
• Настройка VS Code для ...
Курс по python 7 часов:
• Учим python за 7 часов...
Видео про асинхронность:
• Асинхронность, многопо...
Курс по Django 15 часов:
• Полный курс уроков по ...
Курс HTML / CSS:
• Учим HTML и CSS за 7 ч...
Не забудьте подписаться и включить оповещения, чтоб не пропустить новые выпуски!

КОМЕНТАРІ: 190
@S1gmaGam1ng
@S1gmaGam1ng 3 місяці тому
Я ждал это видео 8 дней, автор, пожалуйста прошу, не забрасывай данный курс, именно благодаря твоим роликам и твоему подходу, я заинтересовался программированием и узнал как это интересно, спасибо за то что стараешься!
@cryptomike1577
@cryptomike1577 3 місяці тому
поддерживаю полностью
@spotsman9612
@spotsman9612 3 місяці тому
полностью поддерживаю!
@user-rm1ey8gt7r
@user-rm1ey8gt7r 2 місяці тому
поддерживаю абсолютно
@photo_graf_khv
@photo_graf_khv 4 дні тому
Парень, ты красава! Инфа годная! Большой плюс за ссылку на репозиторий!
@i.troshkin
@i.troshkin 3 місяці тому
Спасибо Вам огромное за этот бесценный труд, вы единственный на ютубе, у которого настолько полезные и информативные курсы и видео, без воды, желаю Вам всего наилучшего, спасибо))
@glebgurzhiy1055
@glebgurzhiy1055 3 місяці тому
спасибо огромное тебе за твои видео,продолжай пожалуйста,это САМЫЙ ПОЛЕЗНЫЙ КУРС ПО AIOGRAM на ютубе
@photo_graf_khv
@photo_graf_khv 2 дні тому
как же мне жаль, что я не нашел это видео раньше! Большое спасибо!
@user-om4ws1em7g
@user-om4ws1em7g 3 місяці тому
Хахах, я тоже очень ждал продолжения)) Два дня просматривал новости с вашего канала. Огромное спасибо автору!!!
@user-hh3jt4gs2q
@user-hh3jt4gs2q Місяць тому
Это самый лучший и подробный курс по aiogram, который я когда-либо находил! Спасибо огромное за ваш труд!
@RoboTron_Channel
@RoboTron_Channel 3 місяці тому
Ура! Смотрю видео и параллельно поправляю свой код, и приговаривая: - Какие вы молодцы, как грамотно сделали. Спасибо большое!
@robertfalken2699
@robertfalken2699 3 місяці тому
Новое видео как целое событие, подписан на все уведомления=) Автору респект!
@Great_Ave
@Great_Ave 2 місяці тому
Пожалуйста, не забрасывайте курс! Очень познавательно. Dialog еще остался как минимум
@Great_Ave
@Great_Ave 2 місяці тому
Под Dialog имею ввиду сцены, например для бота-опросника
@Vladimir_F609
@Vladimir_F609 3 місяці тому
Большое Вам спасибо за Вашу работу!!!
@gachimuchi8732
@gachimuchi8732 2 місяці тому
Большое спасибо! Ваши уроки помогают делать проект для защиты в Вузе!
@IvaschenkoN
@IvaschenkoN 3 місяці тому
спасибо за классный материал, да интересную подачу и за ответы на наши вопросы. с нетерпением жду следующий урок! )
@alsoduos
@alsoduos 3 місяці тому
Давно я не ждал выходных с таким нетерпением, чтобы полностью проработать и просмотреть очередной офигенный урок! Спасибо Вам огромное за Ваш труд!!!
@picha_titan
@picha_titan 3 місяці тому
Большое спасибо за Вашу работу. Вы хороший человек.
@MrSasuke1337
@MrSasuke1337 2 місяці тому
Автор, вы самый лучший, я хоть и не начинал ещё изучать базу данных, но я понял все в вашем видео!😊
@user-rq7sv7bi2m
@user-rq7sv7bi2m 3 місяці тому
Всем Здравствуйте! Поддерживаю, бесценный труд. Большое спасибо вам
@pavku
@pavku 2 місяці тому
Ставим больше лайков автору! А то все благодарны, а лайки зажали! Пробежались по всем видео и поставили лайкосы!
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 3 місяці тому
Долгожданное видео 👍👍👍
@Oleg_57rus
@Oleg_57rus 3 місяці тому
Здраствуйте, большое спасибо Вам.
@shemyatin_konstantin
@shemyatin_konstantin 3 місяці тому
Спасибо, очень ждал это видео. Надеюсь далее будет рассмотрен Redis, например в качестве хранилища у FSM. Также, если можно, рассмотрите защиту от спамеров, так называемый троттлинг. Большое спасибо еще раз за ваш большой труд!
@homelessandhungry4529
@homelessandhungry4529 2 місяці тому
Лучший ресурс по Python! Автор как близкий друг уже
@jekagolosoff
@jekagolosoff 3 місяці тому
Посмотрел как сериал, спасибо.
@user-xe3yf7nu8n
@user-xe3yf7nu8n Місяць тому
Круто, спасибо!
@ilya1.079
@ilya1.079 Місяць тому
Лучший канал по python
@Rasulov_Shop
@Rasulov_Shop 3 місяці тому
Было бы интересно посмотреть как ты объясняешл докер и в целом контейнерезацию. Буду ждать видос
@sanyajc5300
@sanyajc5300 3 місяці тому
Вот сколько смотрю, что по aiogram v2, что по aiogram v3, вот сразу в глаза бросается, как автор кнопки реплай любит больше чём инлайн))) Спасибо за ваш труд)
@PythonHubStudio
@PythonHubStudio 3 місяці тому
В следующем видео они вам тоже не понравятся))) Будем делать многоуровневое меню, каталог, корзину через них
@sanyajc5300
@sanyajc5300 3 місяці тому
@@PythonHubStudio а у меня вот полтергейст с aiogram, с год наверно висит на сервере бот ещё на aiogram 2.23.1, всё работает исправно. А вот с компа его в PyCharm запускаю, команды все работают, а инлайн кнопки молчат.
@user-sv3vi6yp5c
@user-sv3vi6yp5c 2 місяці тому
Спасибо Вам за ваш труд! Жду Ваших новых роликов. Скажите, будет ли дальше telegram wep app?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Ещё не знаю буду делать или нет
@gektorat
@gektorat 2 місяці тому
братишька, давай еще видео!
@deadmalina
@deadmalina 3 місяці тому
Здраствуйте. мне нужно написать бота для регистрации клиентов в салон красоты . подскажите пожалуйста в следующем видео как правильно обратиться к базе данных чтоб она проверила есть ли какая то запись на такое то время и если есть то об этом сообщила и попросила клиента выбрать другое время. буду очень благодарен так как сам пока понять не могу
@ciklomat
@ciklomat 3 місяці тому
Ценная информация, но если бы не то-есть и скажем так! Было бы вообще супер.
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Согласен, скажем так)
@ciklomat
@ciklomat 3 місяці тому
@@PythonHubStudio Рад что реакция позитивная. Программист может быть чрезмерно увлечен языком программирования забывая, что он говорит на русском. А речь способна засорятся из окружающей нас среды, И ученик смотрящий разных блогеров не может понять, а как же правильно писать нужный ему метод из сони предложенных, написанных на одном языке по разному.
@pnpn218
@pnpn218 2 місяці тому
Спасибо!
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Благодарю за поддержку 👍
@pnpn218
@pnpn218 2 місяці тому
Написал по вопросу о сотрудничестве, вы не отвечаете. Как с вами можно связаться?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Нашел ваше письмо, К сожалению, менторством и работой с частными проектами не занимаюсь. Вопросы по видео или советы - через комментарии.
@qweqweqweqweqweqweqweqw
@qweqweqweqweqweqweqweqw 3 місяці тому
Лучший, благодаря тебе давным давно сделал телеграм бота и после этого теперь могу любой сложности сделать. И вот вопрос, сильно ли отличается aiogram 2 от3 ? Стоит ли пересмотреть курс новой версии?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Нововведений достаточно, но тут смотрите сами что вам нужно или нет.
@desorrmarkovskii8648
@desorrmarkovskii8648 2 місяці тому
Будет ли 3 часть для django home курса?
@AA-po3tq
@AA-po3tq 3 місяці тому
Здравствуйте. А сколько у вас ушло примерно времени от самого начала освоения программирования до первой зарплаты?
@user-cp8ou1ot5z
@user-cp8ou1ot5z 3 місяці тому
Еще клево было бы добавить какие то запланированные задачи по Cron. Например каждую минуту отправлять сообщение в чат. Например выкладывать статистику какую ни будь в чат.
@USER_____Oo_____USER
@USER_____Oo_____USER 2 місяці тому
Очень крутой курс, за токое другие деньги берут) спасибо автору за крутой контент!!! Подскажи плиз такую штуку - убрать возможность набирать текст, can_send_messages, например при выборе только из кнопок, куда это сунуть?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Просто удаляйте все что пользователь вводит не с вашей клавиатуры
@lexab3406
@lexab3406 3 місяці тому
Курс одним словом пушка.За ет однозначно лайк неглядя. По поводу БД есть ряд вопросов. 1. В чем отличия прямих запросов в базу даних от SqlAlchemy? Что в целом лутше (и правильнее) изпользовать для тех ти иних ботов? На что обратить внимание что би стать хорошим профильним програмистом? 2. Как можно и возможно ли вообще изпользовать несколько баз даних одна как видео SQL 3 и вторая PostgreSQL? 3. Будет ли дальнейшие видео о создании личного кабинета как пользователя так и админа? Очень би хотелось би увидеть как можно грамотно реализовать для админа ввод и смена пароля по "ключу " ? Очень хотелось би увидеть так как ви отлично на примерах можете об'яснить что к чему и почему.
@PythonHubStudio
@PythonHubStudio 3 місяці тому
1) Отличие в том чтоб не писать запросы самому на языке sql и чтоб не писать с нуля самому методы по взаимодействию, в вариантах с этими же запросами, с базой данных. Правильнее тут нет... Потому что требования к проектам разные. Скорость разработки - своё. Если пишите сами (на заказ) - однозначно работа через orm(sqlalchemy и подобное), если работать в команде, там уже могут быть варианты (возможно будет реализована своя система с запросами к базе с использованием нативного sql). 2) SQLite - это база данных для работы приложения в "одно лицо", годиться в основном только для хранения данных для приложения, в котором только один пользователь (одно приложение) получает к нему доступ (или для легко нагруженного бота, который работает у вас на ПК), для работы с высокой нагрузкой и множеством подключений нужно PostgreSQL и подобные решения
@lexab3406
@lexab3406 3 місяці тому
@@PythonHubStudio Бладарю за ответ.
@lexab3406
@lexab3406 3 місяці тому
@@PythonHubStudio тоисть я правильно понимаю что для викторин каких то информационих ботов можно использовать sql3 lite, а для магазинов или каких то комерческих проектов то PostgreSql?
@lexab3406
@lexab3406 3 місяці тому
@@PythonHubStudio и еще такой возможно уточняющий вопрос: если бот бил написан с использованием sql 3 lite на прямих запросах без использования sqlalchemy. Как его перевести на PostgreSql? Прийдеться переписивать с нуля код с запросами в БД или нет?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Отличие между синтаксисом в SQLite и PostgreSQL мизерное... Может быть придется пару запросов переделать
@kootlife9432
@kootlife9432 3 місяці тому
@PythonHubStudio, здравствуйте спасибо за бесценные уроки, но хотелось бы узнать будет ли продолжение курса, а то это видео оборвалось даже без тизеров не так как раньше. Если курс окончен вы хоть скажите что бы мы не ждали продолжение😭😭😭. В дополнение тоже бы хотелось уточнить "Будут ли реализованы корзина, кнопки для добавления позиций меню, оплата" Хотелось бы узнать как сделать так что бы при выборе товара все остальное что было написано до этого скрывалось?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Продолжение будет, тизерил где-то в середине видео))) В следующем видео точно будет пагинация товаров (инайн меню) и... точного сценария пока нет
@kootlife9432
@kootlife9432 3 місяці тому
@@PythonHubStudio Добрый день жду следующего видео с нетерпением, мб хоть скажите когда ждать?)
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Как бы ни хотелось быстрее, не получается, не успеваю всё совмещать... Но следующее видео будет большим: многоуровневое онлайн меню(меню, каталог, корзина товаров пользователя). Когда точно не скажу...
@IvaschenkoN
@IvaschenkoN 3 місяці тому
есть предложение провести рефакторинг и разделить код в обработчиках. На 1:21:30 вот это "где-где-где" как раз остро намекает о необходимости разделить. я тоже в процессе написания бегал так по коду высматривая нужные строки, а когда услышал уже знакомое для себя "где-где" понял, что проблема прям массовая )
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Абсолютно согласен!👍 Но именно там вроде некуда делить, разве что fsm вынести отдельно, но тогда в том файле останется только 3 хендлера.... Диалоги они такие...
@user-xo2bl2vz3o
@user-xo2bl2vz3o 3 місяці тому
Доброго времени, автор! Нуждаюсь в вашем совете Скажите, на парсинге можно заработать? Пробовал веб разработку, но учить много и не так просто попасть на джуна, да и джунов полно уже Хотел поинтересоватся, если нацелится только лишь на парсинг, ну + телеграмм боты например (или что ещё нужно освоить?), можно ли в скором времени на фрилансе брать заказы, или тоже не годный вариант? Не хочу бросать программирование, но и без быстрого результата, тоже скучно, так сказать Помогите советом
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Можно, на этом зарабатывают, я так начинал. Во фрилансе все зависит от личных качеств: насколько хорошо у вас получится брать заказы и что самое главное - набить постоянную аудиторию клиентов (повторные обращения, ваш личный рейтинг на фриланс платформах, заказы с последующей долгосрочной поддержкой и тд..., чтоб не сидеть только на случайно пойманных заказах). Одного парсинга маловато (но для начала пойдет), если + боты уже лучше. Но самый главный совет - не бросайте то что уже знаете и достигли.
@Kovryzhkin
@Kovryzhkin 3 місяці тому
Спасибо автору. Тяжелый труд, но тысячи благодарных учеников по этому курсу. С нетерпением хочу дописать по этим урокам бота и использовать его как отличную базу для дальнейших работ. В процессе теста возник вопрос. Часто товары вводим на кирилице и в цене автоматом ставим запятую вместо точки. Функция Float это не пропускает и отправляет на проверку ошибки. Читал, что можно это делать с помощью модуля LOCALE. Подскажите как это исправить, может есть какой то вообще простой метод?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Проще так: if ',' in text: text = text.replace(',', '.')
@Kovryzhkin
@Kovryzhkin 3 місяці тому
Огромное ​спасибо за ответ. Действительно просто. Хотел ещё спросить. Было бы не плохо, чтобы в админ хендлере после удаления товара его карточка тоже сразу удалялась с чата чтоб не перегружать его информацией и не делать новый запрос на выборку номенклатуры. Это будет дальше реализовано или искать методы самому? @@PythonHubStudio
@Kovryzhkin
@Kovryzhkin 3 місяці тому
После этого урока еще выскочил баг. Понятно, что на этом этапе урока мы уже все намного умнее, но... Если при добавлении товара в фото указать точку (не при изменении, а именно при добавлении), то выводит ошибку не в чат, а в терминал AttributeError: 'NoneType' object has no attribute 'image'. Или у меня ошибка в коде, или действительно так? @@PythonHubStudio
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Нужно добавить дополнительное условие в хендлер, на проверку есть ли товар для изменения
@user-mj7kp5ns6n
@user-mj7kp5ns6n 3 місяці тому
Очень познавательно видео. Почему мы не используем асинхронность при создании кнопок?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Потому что там ждать нечего, их код выполняется сразу без задержек на ожидание чего-то, например на получение ответа от сервера или от бд
@user-mj7kp5ns6n
@user-mj7kp5ns6n 3 місяці тому
@@PythonHubStudio Спасибо за быстрый ответ. Жду следующего видео ролика
@ndyar6144
@ndyar6144 2 місяці тому
Автор, спасибо за бесценные видео! Немного глупый вопрос - как корректно передавать параметры в dp.shutdown.register(on_shutdown), если я хочу, допустим, снести БД? пробовал кидать в бота, но не то(
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Так как было в on_startup функции.
@user-nd4lm2px8p
@user-nd4lm2px8p 3 місяці тому
Покажите как добавить на самое первое сообщение от бота (start) фотографию над текстом или gif файл. Благодарю!
@PythonHubStudio
@PythonHubStudio 3 місяці тому
.answer_photo(InputFile(фото)или id или url фото в виде строки, captions=текст) Или сначала просто без описания фотку, и следом текст
@usbusb8839
@usbusb8839 2 місяці тому
Когда новое видео?
@user-wi8ks3ce9z
@user-wi8ks3ce9z 9 днів тому
Спасибо за видео! Хотелось бы узнать не сталкивались ли вы с ошибкой Unclosed client session. Весь код с вашего видео, использую postgresql в docker контейнере, когда запускаю бота с хоста и подключаю его к docker контейнеру с бд, всё работает отлично. Упаковываю код бота в контейнер и подключаю к контейнеру бд, выдает ошибки Unclosed client session и Unclosed connector. Гуглить получается, а вот советы не работают. Не понимаю как правильно закрывать соединение в коде. Если можете подсказать, будет очень здорово. Видео хорошее, спасибо:)
@PythonHubStudio
@PythonHubStudio 7 днів тому
Во первых, эта ошибка не имеет значения, потому что ваш бот и так 'ложится' при ошибке и его нужно перезапускать. Во вторых, ошибка очень странная, такое обычно бывает когда ресурсов ПК не хватает на вовремя закрытие сессии. Можете указать в функции "on shutdown" закрытие сессии бд "session maker"-a (это будет как действие при экстренных случаях)
@Fankaipon
@Fankaipon 3 місяці тому
Как сделать бота, которого можно было бы добавить в чат, чтобы бот считал сообщения пользователей и за каждые 50 сообщений давал 5 к балансу пользователя в боте
@IvaschenkoN
@IvaschenkoN 2 місяці тому
Python Hub Studio, надеюсь у тебя все ок. возвращайся в прежний ритм. 2 недели прошло с последнего урока, мы ждем продолжения курса! )
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Все ок, время.... На днях будет следующий: многоуровневое инлайн меню, корзина товаров, пагинация.
@IvaschenkoN
@IvaschenkoN 3 місяці тому
огонь! я вот заметил особенность: весь проект в функциональном стиле, а фильтры и мидлвары в ООП. Чем обусловлен такой подход?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Где что удобнее... Фильтры и прочее удобнее и проще в классах, а хендлеры и прочее удобнее в функциях (когда это свой проект - делаешь так как это удобнее самому). Классы для всего - это не панацея, а зачастую лишь требование загнанного в угол руководителя проекта, а отсюда и стереотипы)))
@IvaschenkoN
@IvaschenkoN 3 місяці тому
@@PythonHubStudio пасиб ) и еще вопрос с 14й минуты (возможно дальше будет ответ... кто знает) мидлвар, прописанный в admin_router.message.middleware(CounterMiddleware()) увеличивает счетчик при любом обращении к admin_router, а выводит на экран результат только при Delete Product. Хотя в декораторе @admin_router.message(F.text == "Delete Product") тоже фильтрация происходит. Есть ли какой то способ навешивать мидлвар на конкретную функцию, а не на весь роутер?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Нет, только на роутер - до или после фильтров
@serjioautoexec4092
@serjioautoexec4092 Місяць тому
Ну да , можно упростить в разы на классах, потом легче переносить в другие проекты. Ассемблер напоминает 😊, взять это копировать туда гоу-ту джамп😊
@i.troshkin
@i.troshkin Місяць тому
Подскажите, в конце ролика использование базы данных SQL postgre это как альтернатива DB sql lite? Можно же пользоваться SQL lite из начала ролика и не устанавливать ту, которая в конце?
@PythonHubStudio
@PythonHubStudio Місяць тому
Можно
@alexlotion5055
@alexlotion5055 2 місяці тому
Спасибо за урок, очень интересно! Однако не без палок в колёсах. На моменте создания базы данных вылазит ошибка ValueError: the greenlet library is required to use this function. No module named 'greenlet' Погуглил, выяснил что проблема как то связана с архитектурой Arm64 моего Мака на M1, но никак не пойму как её решить. Подскажите если знаете
@alexandersamokhin4172
@alexandersamokhin4172 2 місяці тому
pip install sqlalchemy[asyncio]
@rimanagi2110
@rimanagi2110 Місяць тому
Нашел решение проблемы?
@alexlotion5055
@alexlotion5055 Місяць тому
Я всё перетыкал. Вроде помогло pip install sqlalchemy[aiosqlite] Однако не могу утверждать, поскольку в другой раз оно уже не сработало, и, к тому же, когда я решил попробовать создать бд postgress по той же логике pip install sqlalchemy[asyncpg] тоже выдало эту ошибку, поэтому я до сих пор в замешательстве.
@eamarc
@eamarc 3 місяці тому
а где можно посмотреть про стандарт наименования таблиц как существительных в единственном числе? Мне вот только во множественном попадались. Т.е. запросы типа SELECT * FROM products; и дальше каждая запись мапится на product, что в принципе логично...
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Погуглить, но дело в том, что можно и во множественном числе, но негласное соглашение стараться делать в единственном числе, ведь записи в таблице описывают продукт, и чтоб не путаться с -s или без -s, при работе с таблицами, есть негласное правило product а не products
@ivanshinkevich974
@ivanshinkevich974 2 місяці тому
здравствуйте, у меня проблема: Telegram server says - Bad Request: can't parse entities: Unexpected end tag at byte offset 82
@user-yk4zd4sv4s
@user-yk4zd4sv4s 3 місяці тому
Будут ли реализованы корзина, кнопки для добавления позиций меню, оплата?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
В плане есть
@Kovryzhkin
@Kovryzhkin 2 місяці тому
@PythonHubStudio Может можете помочь с вопросом по Middleware? На основе ваших замечательных уроков делаю корпоративный бот и хочу не пропускать в бот тех, кого ещё нет в корп группе. За счёт фильтров мне все понятно, но хочется за счёт внешнего Middleware. И так, и сяк, но упёрся в пень. И не Ai, не Google не помогают. Может ваш светлый, чистый ум и открытое сердце помогут? 😊
@PythonHubStudio
@PythonHubStudio 2 місяці тому
В методе call мидлвари ДО вызова handler(event, data) заберите из TelegramObject или Message id юзера, и потом по аналогии как мы делали с админами в хендлере, только экземпляр бота возьмите из словаря data и используйте метод бота get chat members (вроде так называется), и просто проверьте, если user id в списке участников группы по id, то только тогда пускать дальше, то есть вызывать handler (event, data)
@Kovryzhkin
@Kovryzhkin 2 місяці тому
​@@PythonHubStudioОгромное спасибо. Все вышло. Теперь у меня есть закрытый бот для нужд компании
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Отлично!👍, рад что все получилось!!!
@sufferingtheshadow
@sufferingtheshadow 2 місяці тому
Здравствуйте, повторял всё как в видео, но в конце возникла ошибка при подключении postgresql. Просмотрел на дебаггере, проблема возникает при создании движка. При выполнении строки await conn.run_sync(Base.metadata.create_all), открывается файл библиотеки, как я понял, connect_utils, в ней выполняется функция async def __connect_addr, В которой выполняется условие try: await connected и код завершает работу на куче ошибок. В чём может быть проблема? Использую Windows 10 x64.
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Эта информация, к сожалению ни о чем (не говорит о проблеме, не те выдержки прислали)... Для начала проверьте: 1) установлена и работает ли служба PostgreSQL 2) установлен ли asyncpg 3) правильный ли пароль итд указан
@xjpfxei
@xjpfxei 2 місяці тому
Получается что на каждый клик по кнопке или сообщению открывается новая сессия? А если там будет тысяча кликающих и пишущих пользователей?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Вы очень тонко подметили, я этого не сказал в видео. Поверхностно это так и выглядит, но sqlalchemy сформирует, так называемый, пул транзакций, если они однотипные, и выполнит одно обращение к бд. Суть: 1) 100 пользователей единовременно запросили главную страницу 2) Формируется 100 одинаковых сессий в орм 3) Они объединяются в один запрос (реальную одну сессию по работе с бд), которая выполняет единовременную множественную вставку/обновление/выборку из бд.
@IvaschenkoN
@IvaschenkoN 3 місяці тому
день вопросов продолжается) как решить проблему, когда flake8 ругается на load_dotenv(find_dotenv()) между импортами ?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Можно отключить уведомление о конкретной стилистике. Так писать - нормально, так как подгрузка переменных из окружения должна быть до импорта модуля где создаётся engine. Варианты: 1) Сделать реформат проекта в сторону усложнения для того чтоб использовать подгрузку переменных после имплртов. 2) отключить уведомления от этого уведомления 3) игнорировать
@AndreyLyamkin
@AndreyLyamkin Місяць тому
Доброго дня! Подскажите, пожалуйста, как можно изменить код, чтобы в конце FSM отправлять данные не в чат с админом, а в другую группу? т.е. не await message.answer(str(data)) что-то в виде: await bot.send_message(chat_id,str(data))
@PythonHubStudio
@PythonHubStudio Місяць тому
Вы все правильно написали (метод через bot). В чем именно проблема?
@AndreyLyamkin
@AndreyLyamkin Місяць тому
@@PythonHubStudio ну вот не могу правильно дописать в Вашем примере. Задача: чтобы отправить все данные в «data” не пользователю, а в админский чат
@PythonHubStudio
@PythonHubStudio Місяць тому
await bot.send_message(admin_id, str(data)) Или так как у нас есть список админов на экземпляре бота, то можно и так: await bot.send_messages(bot.admins_list, str(data)) ^ (множественная рассылка по списку id)
@AndreyLyamkin
@AndreyLyamkin Місяць тому
@@PythonHubStudio мне кажется я так писал. Проверю сейчас
@AndreyLyamkin
@AndreyLyamkin Місяць тому
@@PythonHubStudio все получилось, ошибка была в том, что я не передавал bot в хендлере... спасибо
@DataFlex_Studio
@DataFlex_Studio Місяць тому
Подскажите пожалуйста, столкнулся с проблемой... VS Code не всегда предлагает варианты исправления кода как у автора в этом видео. Например на 38:15 "session_maker" подчеркнут желтой линией и Quick Fix предложил вариант с импортом для исправления. Дак вот у меня в этом месте ничего не предлагает исправить, можно только посмотреть проблему. И много таких ситуаций было в течение курса, но иногда все же предлагает варианты для исправления. Quick Fix в настройках везде включен, в расширениях Python установлен последней версии, VS Code так же обновлен до последней версии. Работаю на Mac OS M1. Спасибо всем кто поможет) Я новичок и эта фишка очень помогла бы мне)
@PythonHubStudio
@PythonHubStudio Місяць тому
Проект открыт нормально в редакторе? Или вы открыли папку с этим и кучей других проектов?
@antonstoliarenko2445
@antonstoliarenko2445 3 місяці тому
Курс супер. Но есть вопрос)) код разбит по модулям. В юзер Приват основной код. Но в моем случае в одной из функций сценария нужно вызвать методы бота: dowload , get_file. Я эту функцию вынес в main, но из-за этого и всё остальное пришлось переместить, потому что как мне показалось , логика сценария из-за такого переноса тоже страдает. Можно это как- то исправить?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Как я говорил в этом плейлисте - если нужны методы бота в хендлере, просто добавьте параметр bot: Bot, и экземпляр бота пробросится в хендлер: И юзайте в хендлере методы бота await bot....
@antonstoliarenko2445
@antonstoliarenko2445 2 місяці тому
Действительно) спасибо!! Еще такой вопрос: может ли быть одновременно несколько состояний FSM? Понимаю что это просто другой класс(ы) и не должно быть с этим проблем, но не будет ли конфликта в сценарии?
@nikiost6707
@nikiost6707 Місяць тому
у меня почему-то наоборот вылетает миллиард ошибок после того как подключил базу данных, причем ошибки не схожие вообще
@BEGovoy_DZEN
@BEGovoy_DZEN Місяць тому
Здравствуйте, не вылазит меню после ввода /admin как на видео на 42-й минуте, ошибок никаких нет, в терминале всё как у вас показывает, но вот меню нет. Сначала в группу вбил /admin подтянул админов, а потом уже боту написал, но ничего. Проверил код admin_private.py там всё нормально, слепил из скраншотов видео весь этот файлик, сверил всё идентично. Подскажите в каком файле ещё может быть ошибка. До этого проверка бота была, всё получилось, застрял на 42 минуте.
@PythonHubStudio
@PythonHubStudio Місяць тому
По описанию не могу сказать что не так. Сверьтесь с гитхабом урока.
@g-man7112
@g-man7112 3 місяці тому
Здравствуйте, вроде бы написал код как у Вас, но в админ приват при попытке записи данных в базу данных выдаёт ошибку: KeyError 'image', подскажи пожалуйста что это может быть.(я пишу код в пайчарме) Спасибо! (изменено) ещё есть ошибка "in call return await handler(event, data)" не знаю какая из них главная и вызывает вторую
@user-yg1xt8cb5n
@user-yg1xt8cb5n 7 днів тому
У меня такая же ошибка, только с кейеррор: description
@ustoz_shogird5699
@ustoz_shogird5699 2 місяці тому
Здравствуйте! На аиограм диалог есть видео уроки?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Как вы могли заметить - нет. Будут ли? Вряд-ли, так как фреймворк поверх другого фреймворка ничего хорошего не несёт...(мое мнение). Это если вы имеете ввиду библиотеку по упрощённому созданию диалогов, а не "комнаты" aiogram.
@user-tu5un1dr2m
@user-tu5un1dr2m Місяць тому
ругается на строчки импорт датабейс, хотя вроде все точно так же как у вас, помогите пожалуйста?
@PythonHubStudio
@PythonHubStudio Місяць тому
Возможно проект открыт в редакторе на директорию выше чем положено.
@user-tb9vw5ov3j
@user-tb9vw5ov3j 3 місяці тому
9:46, у меня у одного на этом моменте возникла ошибка "TypeError: CounterMiddleware.__init__() takes 1 positional argument but 4 were given"? И даже если в инициализатор впихнуть *args то потом возникает другая ошибка "TypeError: object CounterMiddleware can't be used in 'await' expression". Вроде всё как на видео, но не получается
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Скиньте сюда код метода init мидлвари и строку где он регистрируется
@glvd3960
@glvd3960 3 місяці тому
​@@PythonHubStudio Регистрация middleware @basecmdRouter.message.outer_middleware(PrivateChatOnlyMiddleware()) Сам код class PrivateChatOnlyMiddleware(BaseMiddleware): async def __call__( self, handler: Callable[[Message, Dict[str, Any]], Awaitable[Any]], event: Message, data: Dict[str, Any], ) -> Any: if F.chat.type.in_(["group", "supergroup"]): await event.answer("ok") return await handler(event, data) TypeError: __call__() missing 2 required positional arguments: 'event' and 'data' Возникает ошибка. Перепробовал достаточно разных примеров мидлвари, все приводят к одному и тому же. Может быть вы сможете подсказать в чем заключается ошибка
@PythonHubStudio
@PythonHubStudio 3 місяці тому
В самом методе call все нормально. Зачем символ декоратора @ в регистрации мидлвари? Просто через объект роутера нужно
@SeDiSlayer
@SeDiSlayer 2 місяці тому
Тоже столкнулся с этой ошибкой, полез гуглить, добавил аргументы и поймал следующую ошибку... Все делал как в видео. Единственное отличие, PyCharm. "dp = Dispatcher() admin_router.message.middleware(CounterMiddleware) dp.include_routers(user_private_router) dp.include_routers(user_group_router) dp.include_routers(admin_router)" Где тут @, я не понял. Python только начал изучать.
@SeDiSlayer
@SeDiSlayer 2 місяці тому
Сори, нашел ошибку. Не внимательный, потерял скобки.
@user-gu1eo9oy1y
@user-gu1eo9oy1y 2 дні тому
Привет , подскажите почему в класс Base не передать id ? Он же тоже будет у всех классов
@PythonHubStudio
@PythonHubStudio 21 годину тому
Можно
@odin_gaming
@odin_gaming Місяць тому
не могу решить никак проблему по добавлению фото. выбивает в терминале ошибку: "TypeError: add_image() missing 1 required positional argument: 'session'". Я уже даже твой код скопировал с гитхаба и все равно таже ошибка, даже с твоим кодом. В чем может быть проблема?
@PythonHubStudio
@PythonHubStudio Місяць тому
А сессию первым аргументом передаёте в add_image(session, ...) ?
@odin_gaming
@odin_gaming Місяць тому
​@@PythonHubStudio попробовал первым вот так: async def add_image(session, message: types.Message, state: FSMContext): и уже пишет что TypeError: add_image() missing 1 required positional argument: 'message'
@odin_gaming
@odin_gaming Місяць тому
если у кого будет подобная проблема. то вот что мне помогло: импортируйте from database.engine import session_maker и потом начинайте функцию вот так: async def add_image(message: types.Message, state: FSMContext): async with session_maker() as session: тут остальное без изиенений
@user-yw7hd8qr1v
@user-yw7hd8qr1v 2 дні тому
не совсем понятно, что такое handler в middleware
@creativejuices91
@creativejuices91 День тому
подскажите пожалуйста как быть без dotenv, он не устанавливается, пришлось просто через конфиг, но тогда файл базы не создаётся
@PythonHubStudio
@PythonHubStudio 21 годину тому
url бд тоже из конфига берите, или установите другую библиотеку для работы с env файлами (их много)
@bahromgafforov9444
@bahromgafforov9444 2 місяці тому
сделаем скидка 3.00 -> 2.99 ))
@PythonHubStudio
@PythonHubStudio 2 місяці тому
😅
@user-ro8iq2kd7w
@user-ro8iq2kd7w 2 місяці тому
Автор доброго времени суток. У меня на сервере установлено MySQL Mariadb и клиент phpmyadmin Mariadb как в таком случае подключаться подскажите?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Погуглите: sqlalchemy для асинхронной MySQL. Будет примерно так: mysql+asyncmy://login: password@localhost/dbname
@user-ro8iq2kd7w
@user-ro8iq2kd7w 2 місяці тому
@@PythonHubStudio спасибо большое. Продолжение будет видео уроков с инструкциями? Учусь, записываю основные моменты
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Следующий видик уже есть, дальше не знаю, буду делать продолжение или нет...
@HetrateHetrate
@HetrateHetrate 2 місяці тому
@@PythonHubStudioделайте обязательно, это единственный ролик на ютубе где я нашел как прокинуть скл алхими и сессии через мидлварь а не через глобальную сессию на ютубе! Очень хороший и качественный контент.
@user-kx1wv2uy9m
@user-kx1wv2uy9m 3 місяці тому
Доброго времени суток. Подскажите плиз при попытке изменения товара в ассортименте, а именно сохранении описания (путем ввода точки в сообщение телеграмм-боту) выдает ошибку File "G:\tg\handlers\admin_private.py", line 177, in add_description await state.update_data(description=AddProduct.product_for_change.description) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ AttributeError: 'ScalarResult' object has no attribute 'description' Пока только учусь этой магии, не судите строго. Все делал по видео, первая ошибка которая появилось на всем пути ))
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Хм... А исходник с GitHub работает?
@user-kx1wv2uy9m
@user-kx1wv2uy9m 2 місяці тому
@@PythonHubStudio хотелось самостоятельно прописать все, но в этом и оказались ошибки. Где то что-то пропустил )) не быть мне код-ревьювером )) А сейчас уже новая ошибка вылезла при подключении уже PostgreSQL где ошибка с URL File "g:\work_place\venv\Lib\site-packages\sqlalchemy\engine\url.py", line 846, in make_url raise exc.ArgumentError( sqlalchemy.exc.ArgumentError: Expected string or URL object, got None
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Видел вопрос решился)
@SpEvgeniy
@SpEvgeniy 5 днів тому
@@PythonHubStudio , привет, не нашел как вопрос решился?, тоже пишу сам, такое ощущение, что product_for_change как то коряво создается... upd: Ну так и есть , начал проверять запрос в базу , по итогу в orm_get_product, указал неверный return - result.scalars(), по итогу поправил на scalar() и все завелось. Вдруг кому пригодится!
@user-wb9wn6vy4g
@user-wb9wn6vy4g 3 місяці тому
Привет! Подскажите что не так- File ......./AppData\Local\Programs\Python\Python39\lib\site-packages\sqlalchemy\engine\url.py", line 846, in make_url raise exc.ArgumentError( sqlalchemy.exc.ArgumentError: Expected string or URL object, got None. Спасибо
@user-kx1wv2uy9m
@user-kx1wv2uy9m 2 місяці тому
разобрался в чем проблема была? а то у меня тоже она выскочила!!
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Url адрес (строка базы данных) не просчиталась из файла .env, os.getenv вернул None, потому что нет переменной указанной в нем (опечатка). Можете там просто как строку url-ку записать
@user-kx1wv2uy9m
@user-kx1wv2uy9m 2 місяці тому
@@PythonHubStudio не поверите, но сегодня запустил опять Ваш код и все заработала без ошибок. Магия в общем )) все загружает в постегр и базы формирует. Спасибо за урок, жду с нетерпением продолжения :)
@vincentvega1391
@vincentvega1391 Місяць тому
Как задонатить?
@BoAnMi
@BoAnMi 2 місяці тому
хьюстон, у меня проблема) не удается разрешить импорт kbds.inline, запускал через venv, даже установил версию python 3.11.1, не помогло, было у кого нибуть такое? гугол молчит на эту проблему
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Не тот файл возможно запускается, нужно запускать app.py. Причины: 1) В прямом смысле запускаете скрипт не с файла app.py 2) После смены папки проекта не создали новый config для "нового" проекта 3) В pycharm тыкнуть правой кнопкой мыши по папке, где лежит app.py и выбрать "пометить как папку проекта"
@BoAnMi
@BoAnMi Місяць тому
@@PythonHubStudio сам накосячил, букву перепутал в названии папки) неделю искал проблему🤣
@PythonHubStudio
@PythonHubStudio Місяць тому
😅норм)
@user-ld6ss8hi8v
@user-ld6ss8hi8v 2 місяці тому
Здравствуйте. Появилась проблема (не появляется файл my_base.db, нет самого приложения с базой данных). Код вроде проверил все верно. Как решить такую проблему?
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Ошибку отображает? Если нет, обновите експлорер файлов в редакторе, если есть ошибка, то рассмотрите ее, или пришлите сюда, посмотрим
@user-ld6ss8hi8v
@user-ld6ss8hi8v 2 місяці тому
​@@PythonHubStudio, никаких ошибок нет. В терминале вылазит вывод sql-запросов. VS Code перезагружал. Файла все равно нет
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Если вылазит вывод sql запросов, то значит все работает правильно, но!, обратите внимание на то как именно вы открыли проект и как его запустили. Файл my_base.db будет в той папке, где запускается терминал в редакторе. Просто в редакторе откройте терминал (terminal> new terminal) и посмотрите какой там указан путь. Суть в том, что проект нужно открывать в редакторе так, чтоб открыть папку в которой app.py, и тогда все будет на своем месте
@user-ld6ss8hi8v
@user-ld6ss8hi8v 2 місяці тому
​​@@PythonHubStudio, благодарю вас за помощь. Действительно помогло. Но приложение так и не нашёл.
@PythonHubStudio
@PythonHubStudio 2 місяці тому
Тут я не понял, сначала пропустил, думал это оборот речи, НО какое приложение имеется ввиду? Если вы имеете ввиду DB Browser (SQLite), то его нужно скачать из интернета, не с какого-то там сайта-агрегатора программ, а с их официального: на всякий случай вот ссылка, где я ее скачал: sqlitebrowser.org/
@catstyle1101
@catstyle1101 3 місяці тому
Если будут править разные карточки два админа одновременно, то будет любопытный результат.
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Да, это не предусмотрено
@Rasulov_Shop
@Rasulov_Shop 3 місяці тому
Алхимия как смысл жизни 😂
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Все хотят изобрести "философский камень")))
@icrypter
@icrypter 3 місяці тому
+
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 3 місяці тому
Уважаемый автор, у меня есть канал на ютубе. Не такой большой как у Вас и немного на другую тему. Я создал бота для помощи водителям на дороге и планирую его усовершенствовать. Сможете помочь?
@PythonHubStudio
@PythonHubStudio 3 місяці тому
Извините, но дел и так очень много... С личным проектом не помогу.
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 3 місяці тому
@@PythonHubStudio если Вы водитель, то это может бесплатно помочь и Вам))) мне нужна элементарная помощь...бот человеку задает некие вопросы, получает ответы, где-то их собирает и в итоге данные из ответов вставляет в pdf файл и отправляет обратно пользователю
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 3 місяці тому
ну если не получится, то извините)))
@evgen3
@evgen3 20 днів тому
У вас что-то с микрофоном не так.Местами по ушам бьет
@PythonHubStudio
@PythonHubStudio 18 днів тому
Приму во внимание!
@IvaschenkoN
@IvaschenkoN 3 місяці тому
куда то пропал мой последний коммент. 1. зачем в админ приват в строке @admin_router.message(AddProduct.name, or_f(F.text, F.text == '.')) условие or_f ? ведь точка входит в множество F.text 2. как и ожидалось при добавлении нового товара с точкой вместо имени - код крашится. нужно обработать
@PythonHubStudio
@PythonHubStudio 3 місяці тому
1) это пример, ведь первое условие не обязательно F.text может быть 2) Да, нужно добавить проверку, это ведь не сложно сделать
@iceongone4490
@iceongone4490 2 місяці тому
Nemo - The Code (LIVE) | Switzerland🇨🇭| Grand Final | Eurovision 2024
03:28
Eurovision Song Contest
Переглядів 14 млн
didn't want to let me in #tiktok
00:20
Анастасия Тарасова
Переглядів 8 млн
Маленькая и средняя фанта
00:56
Multi DO Smile Russian
Переглядів 1,9 млн
Nemo - The Code (LIVE) | Switzerland🇨🇭| Grand Final | Eurovision 2024
03:28
Eurovision Song Contest
Переглядів 14 млн