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

  Рет қаралды 21,233

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 ч...
Не забудьте подписаться и включить оповещения, чтоб не пропустить новые выпуски!

Пікірлер: 213
@S1gmaGam1ng
@S1gmaGam1ng 4 ай бұрын
Я ждал это видео 8 дней, автор, пожалуйста прошу, не забрасывай данный курс, именно благодаря твоим роликам и твоему подходу, я заинтересовался программированием и узнал как это интересно, спасибо за то что стараешься!
@cryptomike1577
@cryptomike1577 4 ай бұрын
поддерживаю полностью
@spotsman9612
@spotsman9612 4 ай бұрын
полностью поддерживаю!
@user-rm1ey8gt7r
@user-rm1ey8gt7r 4 ай бұрын
поддерживаю абсолютно
@i.troshkin
@i.troshkin 4 ай бұрын
Спасибо Вам огромное за этот бесценный труд, вы единственный на ютубе, у которого настолько полезные и информативные курсы и видео, без воды, желаю Вам всего наилучшего, спасибо))
@glebgurzhiy1055
@glebgurzhiy1055 4 ай бұрын
спасибо огромное тебе за твои видео,продолжай пожалуйста,это САМЫЙ ПОЛЕЗНЫЙ КУРС ПО AIOGRAM на ютубе
@robertfalken2699
@robertfalken2699 4 ай бұрын
Новое видео как целое событие, подписан на все уведомления=) Автору респект!
@user-om4ws1em7g
@user-om4ws1em7g 4 ай бұрын
Хахах, я тоже очень ждал продолжения)) Два дня просматривал новости с вашего канала. Огромное спасибо автору!!!
@gachimuchi8732
@gachimuchi8732 4 ай бұрын
Большое спасибо! Ваши уроки помогают делать проект для защиты в Вузе!
@alsoduos
@alsoduos 4 ай бұрын
Давно я не ждал выходных с таким нетерпением, чтобы полностью проработать и просмотреть очередной офигенный урок! Спасибо Вам огромное за Ваш труд!!!
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
спасибо за классный материал, да интересную подачу и за ответы на наши вопросы. с нетерпением жду следующий урок! )
@RoboTron_Channel
@RoboTron_Channel 4 ай бұрын
Ура! Смотрю видео и параллельно поправляю свой код, и приговаривая: - Какие вы молодцы, как грамотно сделали. Спасибо большое!
@user-hh3jt4gs2q
@user-hh3jt4gs2q 3 ай бұрын
Это самый лучший и подробный курс по aiogram, который я когда-либо находил! Спасибо огромное за ваш труд!
@Vladimir_F609
@Vladimir_F609 4 ай бұрын
Большое Вам спасибо за Вашу работу!!!
@MrSasuke1337
@MrSasuke1337 3 ай бұрын
Автор, вы самый лучший, я хоть и не начинал ещё изучать базу данных, но я понял все в вашем видео!😊
@photo_graf_khv
@photo_graf_khv Ай бұрын
Парень, ты красава! Инфа годная! Большой плюс за ссылку на репозиторий!
@picha_titan
@picha_titan 4 ай бұрын
Большое спасибо за Вашу работу. Вы хороший человек.
@Great_Ave
@Great_Ave 3 ай бұрын
Пожалуйста, не забрасывайте курс! Очень познавательно. Dialog еще остался как минимум
@Great_Ave
@Great_Ave 3 ай бұрын
Под Dialog имею ввиду сцены, например для бота-опросника
@user-rq7sv7bi2m
@user-rq7sv7bi2m 4 ай бұрын
Всем Здравствуйте! Поддерживаю, бесценный труд. Большое спасибо вам
@Oleg_57rus
@Oleg_57rus 4 ай бұрын
Здраствуйте, большое спасибо Вам.
@shemyatin_konstantin
@shemyatin_konstantin 4 ай бұрын
Спасибо, очень ждал это видео. Надеюсь далее будет рассмотрен Redis, например в качестве хранилища у FSM. Также, если можно, рассмотрите защиту от спамеров, так называемый троттлинг. Большое спасибо еще раз за ваш большой труд!
@pavku
@pavku 4 ай бұрын
Ставим больше лайков автору! А то все благодарны, а лайки зажали! Пробежались по всем видео и поставили лайкосы!
@photo_graf_khv
@photo_graf_khv Ай бұрын
как же мне жаль, что я не нашел это видео раньше! Большое спасибо!
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 4 ай бұрын
Долгожданное видео 👍👍👍
@homelessandhungry4529
@homelessandhungry4529 3 ай бұрын
Лучший ресурс по Python! Автор как близкий друг уже
@jekagolosoff
@jekagolosoff 4 ай бұрын
Посмотрел как сериал, спасибо.
@ilya1.079
@ilya1.079 3 ай бұрын
Лучший канал по python
@Rasulov_Shop
@Rasulov_Shop 4 ай бұрын
Было бы интересно посмотреть как ты объясняешл докер и в целом контейнерезацию. Буду ждать видос
@user-xe3yf7nu8n
@user-xe3yf7nu8n 2 ай бұрын
Круто, спасибо!
@sanyajc5300
@sanyajc5300 4 ай бұрын
Вот сколько смотрю, что по aiogram v2, что по aiogram v3, вот сразу в глаза бросается, как автор кнопки реплай любит больше чём инлайн))) Спасибо за ваш труд)
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
В следующем видео они вам тоже не понравятся))) Будем делать многоуровневое меню, каталог, корзину через них
@sanyajc5300
@sanyajc5300 4 ай бұрын
@@PythonHubStudio а у меня вот полтергейст с aiogram, с год наверно висит на сервере бот ещё на aiogram 2.23.1, всё работает исправно. А вот с компа его в PyCharm запускаю, команды все работают, а инлайн кнопки молчат.
@gektorat
@gektorat 4 ай бұрын
братишька, давай еще видео!
@user-sv3vi6yp5c
@user-sv3vi6yp5c 4 ай бұрын
Спасибо Вам за ваш труд! Жду Ваших новых роликов. Скажите, будет ли дальше telegram wep app?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Ещё не знаю буду делать или нет
@ciklomat
@ciklomat 4 ай бұрын
Ценная информация, но если бы не то-есть и скажем так! Было бы вообще супер.
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Согласен, скажем так)
@ciklomat
@ciklomat 4 ай бұрын
@@PythonHubStudio Рад что реакция позитивная. Программист может быть чрезмерно увлечен языком программирования забывая, что он говорит на русском. А речь способна засорятся из окружающей нас среды, И ученик смотрящий разных блогеров не может понять, а как же правильно писать нужный ему метод из сони предложенных, написанных на одном языке по разному.
@pnpn218
@pnpn218 4 ай бұрын
Спасибо!
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Благодарю за поддержку 👍
@pnpn218
@pnpn218 4 ай бұрын
Написал по вопросу о сотрудничестве, вы не отвечаете. Как с вами можно связаться?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Нашел ваше письмо, К сожалению, менторством и работой с частными проектами не занимаюсь. Вопросы по видео или советы - через комментарии.
@user-cp8ou1ot5z
@user-cp8ou1ot5z 4 ай бұрын
Еще клево было бы добавить какие то запланированные задачи по Cron. Например каждую минуту отправлять сообщение в чат. Например выкладывать статистику какую ни будь в чат.
@qweqweqweqweqweqweqweqw
@qweqweqweqweqweqweqweqw 4 ай бұрын
Лучший, благодаря тебе давным давно сделал телеграм бота и после этого теперь могу любой сложности сделать. И вот вопрос, сильно ли отличается aiogram 2 от3 ? Стоит ли пересмотреть курс новой версии?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Нововведений достаточно, но тут смотрите сами что вам нужно или нет.
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
Python Hub Studio, надеюсь у тебя все ок. возвращайся в прежний ритм. 2 недели прошло с последнего урока, мы ждем продолжения курса! )
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Все ок, время.... На днях будет следующий: многоуровневое инлайн меню, корзина товаров, пагинация.
@deadmalina
@deadmalina 4 ай бұрын
Здраствуйте. мне нужно написать бота для регистрации клиентов в салон красоты . подскажите пожалуйста в следующем видео как правильно обратиться к базе данных чтоб она проверила есть ли какая то запись на такое то время и если есть то об этом сообщила и попросила клиента выбрать другое время. буду очень благодарен так как сам пока понять не могу
@i.troshkin
@i.troshkin 3 ай бұрын
Подскажите, в конце ролика использование базы данных SQL postgre это как альтернатива DB sql lite? Можно же пользоваться SQL lite из начала ролика и не устанавливать ту, которая в конце?
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Можно
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
есть предложение провести рефакторинг и разделить код в обработчиках. На 1:21:30 вот это "где-где-где" как раз остро намекает о необходимости разделить. я тоже в процессе написания бегал так по коду высматривая нужные строки, а когда услышал уже знакомое для себя "где-где" понял, что проблема прям массовая )
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Абсолютно согласен!👍 Но именно там вроде некуда делить, разве что fsm вынести отдельно, но тогда в том файле останется только 3 хендлера.... Диалоги они такие...
@AA-po3tq
@AA-po3tq 4 ай бұрын
Здравствуйте. А сколько у вас ушло примерно времени от самого начала освоения программирования до первой зарплаты?
@desorrmarkovskii8648
@desorrmarkovskii8648 4 ай бұрын
Будет ли 3 часть для django home курса?
@kootlife9432
@kootlife9432 4 ай бұрын
@PythonHubStudio, здравствуйте спасибо за бесценные уроки, но хотелось бы узнать будет ли продолжение курса, а то это видео оборвалось даже без тизеров не так как раньше. Если курс окончен вы хоть скажите что бы мы не ждали продолжение😭😭😭. В дополнение тоже бы хотелось уточнить "Будут ли реализованы корзина, кнопки для добавления позиций меню, оплата" Хотелось бы узнать как сделать так что бы при выборе товара все остальное что было написано до этого скрывалось?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Продолжение будет, тизерил где-то в середине видео))) В следующем видео точно будет пагинация товаров (инайн меню) и... точного сценария пока нет
@kootlife9432
@kootlife9432 4 ай бұрын
@@PythonHubStudio Добрый день жду следующего видео с нетерпением, мб хоть скажите когда ждать?)
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Как бы ни хотелось быстрее, не получается, не успеваю всё совмещать... Но следующее видео будет большим: многоуровневое онлайн меню(меню, каталог, корзина товаров пользователя). Когда точно не скажу...
@USER_____Oo_____USER
@USER_____Oo_____USER 3 ай бұрын
Очень крутой курс, за токое другие деньги берут) спасибо автору за крутой контент!!! Подскажи плиз такую штуку - убрать возможность набирать текст, can_send_messages, например при выборе только из кнопок, куда это сунуть?
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Просто удаляйте все что пользователь вводит не с вашей клавиатуры
@user-xo2bl2vz3o
@user-xo2bl2vz3o 4 ай бұрын
Доброго времени, автор! Нуждаюсь в вашем совете Скажите, на парсинге можно заработать? Пробовал веб разработку, но учить много и не так просто попасть на джуна, да и джунов полно уже Хотел поинтересоватся, если нацелится только лишь на парсинг, ну + телеграмм боты например (или что ещё нужно освоить?), можно ли в скором времени на фрилансе брать заказы, или тоже не годный вариант? Не хочу бросать программирование, но и без быстрого результата, тоже скучно, так сказать Помогите советом
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Можно, на этом зарабатывают, я так начинал. Во фрилансе все зависит от личных качеств: насколько хорошо у вас получится брать заказы и что самое главное - набить постоянную аудиторию клиентов (повторные обращения, ваш личный рейтинг на фриланс платформах, заказы с последующей долгосрочной поддержкой и тд..., чтоб не сидеть только на случайно пойманных заказах). Одного парсинга маловато (но для начала пойдет), если + боты уже лучше. Но самый главный совет - не бросайте то что уже знаете и достигли.
@lexab3406
@lexab3406 4 ай бұрын
Курс одним словом пушка.За ет однозначно лайк неглядя. По поводу БД есть ряд вопросов. 1. В чем отличия прямих запросов в базу даних от SqlAlchemy? Что в целом лутше (и правильнее) изпользовать для тех ти иних ботов? На что обратить внимание что би стать хорошим профильним програмистом? 2. Как можно и возможно ли вообще изпользовать несколько баз даних одна как видео SQL 3 и вторая PostgreSQL? 3. Будет ли дальнейшие видео о создании личного кабинета как пользователя так и админа? Очень би хотелось би увидеть как можно грамотно реализовать для админа ввод и смена пароля по "ключу " ? Очень хотелось би увидеть так как ви отлично на примерах можете об'яснить что к чему и почему.
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
1) Отличие в том чтоб не писать запросы самому на языке sql и чтоб не писать с нуля самому методы по взаимодействию, в вариантах с этими же запросами, с базой данных. Правильнее тут нет... Потому что требования к проектам разные. Скорость разработки - своё. Если пишите сами (на заказ) - однозначно работа через orm(sqlalchemy и подобное), если работать в команде, там уже могут быть варианты (возможно будет реализована своя система с запросами к базе с использованием нативного sql). 2) SQLite - это база данных для работы приложения в "одно лицо", годиться в основном только для хранения данных для приложения, в котором только один пользователь (одно приложение) получает к нему доступ (или для легко нагруженного бота, который работает у вас на ПК), для работы с высокой нагрузкой и множеством подключений нужно PostgreSQL и подобные решения
@lexab3406
@lexab3406 4 ай бұрын
@@PythonHubStudio Бладарю за ответ.
@lexab3406
@lexab3406 4 ай бұрын
@@PythonHubStudio тоисть я правильно понимаю что для викторин каких то информационих ботов можно использовать sql3 lite, а для магазинов или каких то комерческих проектов то PostgreSql?
@lexab3406
@lexab3406 4 ай бұрын
@@PythonHubStudio и еще такой возможно уточняющий вопрос: если бот бил написан с использованием sql 3 lite на прямих запросах без использования sqlalchemy. Как его перевести на PostgreSql? Прийдеться переписивать с нуля код с запросами в БД или нет?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Отличие между синтаксисом в SQLite и PostgreSQL мизерное... Может быть придется пару запросов переделать
@user-sd6rx4sj1r
@user-sd6rx4sj1r 11 күн бұрын
Добрый день! Спасибо вам за классно преподнесенный материал. Хотел уточнить информацию, вот как самому научиться писать то что вы делаете? Как вы понимаете какие функции надо писать? Просто столько инфы полезной, но хотелось бы от вас (развернутый по возможности) ответ. Потому что, сам сижу читаю документацию либо ничего не понимаю либо не могу найти информацию Спасибо еще раз за контент
@PythonHubStudio
@PythonHubStudio 9 күн бұрын
Я этому много уделил времени в плейлисте этих видео - чтение документации api telegram и aiogram. Только такой путь.
@ndyar6144
@ndyar6144 3 ай бұрын
Автор, спасибо за бесценные видео! Немного глупый вопрос - как корректно передавать параметры в dp.shutdown.register(on_shutdown), если я хочу, допустим, снести БД? пробовал кидать в бота, но не то(
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Так как было в on_startup функции.
@user-yk4zd4sv4s
@user-yk4zd4sv4s 4 ай бұрын
Будут ли реализованы корзина, кнопки для добавления позиций меню, оплата?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
В плане есть
@Kovryzhkin
@Kovryzhkin 4 ай бұрын
Спасибо автору. Тяжелый труд, но тысячи благодарных учеников по этому курсу. С нетерпением хочу дописать по этим урокам бота и использовать его как отличную базу для дальнейших работ. В процессе теста возник вопрос. Часто товары вводим на кирилице и в цене автоматом ставим запятую вместо точки. Функция Float это не пропускает и отправляет на проверку ошибки. Читал, что можно это делать с помощью модуля LOCALE. Подскажите как это исправить, может есть какой то вообще простой метод?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Проще так: if ',' in text: text = text.replace(',', '.')
@Kovryzhkin
@Kovryzhkin 4 ай бұрын
Огромное ​спасибо за ответ. Действительно просто. Хотел ещё спросить. Было бы не плохо, чтобы в админ хендлере после удаления товара его карточка тоже сразу удалялась с чата чтоб не перегружать его информацией и не делать новый запрос на выборку номенклатуры. Это будет дальше реализовано или искать методы самому? @@PythonHubStudio
@Kovryzhkin
@Kovryzhkin 4 ай бұрын
После этого урока еще выскочил баг. Понятно, что на этом этапе урока мы уже все намного умнее, но... Если при добавлении товара в фото указать точку (не при изменении, а именно при добавлении), то выводит ошибку не в чат, а в терминал AttributeError: 'NoneType' object has no attribute 'image'. Или у меня ошибка в коде, или действительно так? @@PythonHubStudio
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Нужно добавить дополнительное условие в хендлер, на проверку есть ли товар для изменения
@user-mj7kp5ns6n
@user-mj7kp5ns6n 4 ай бұрын
Очень познавательно видео. Почему мы не используем асинхронность при создании кнопок?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Потому что там ждать нечего, их код выполняется сразу без задержек на ожидание чего-то, например на получение ответа от сервера или от бд
@user-mj7kp5ns6n
@user-mj7kp5ns6n 4 ай бұрын
@@PythonHubStudio Спасибо за быстрый ответ. Жду следующего видео ролика
@usbusb8839
@usbusb8839 4 ай бұрын
Когда новое видео?
@user-nd4lm2px8p
@user-nd4lm2px8p 4 ай бұрын
Покажите как добавить на самое первое сообщение от бота (start) фотографию над текстом или gif файл. Благодарю!
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
.answer_photo(InputFile(фото)или id или url фото в виде строки, captions=текст) Или сначала просто без описания фотку, и следом текст
@user-wi8ks3ce9z
@user-wi8ks3ce9z Ай бұрын
Спасибо за видео! Хотелось бы узнать не сталкивались ли вы с ошибкой Unclosed client session. Весь код с вашего видео, использую postgresql в docker контейнере, когда запускаю бота с хоста и подключаю его к docker контейнеру с бд, всё работает отлично. Упаковываю код бота в контейнер и подключаю к контейнеру бд, выдает ошибки Unclosed client session и Unclosed connector. Гуглить получается, а вот советы не работают. Не понимаю как правильно закрывать соединение в коде. Если можете подсказать, будет очень здорово. Видео хорошее, спасибо:)
@PythonHubStudio
@PythonHubStudio Ай бұрын
Во первых, эта ошибка не имеет значения, потому что ваш бот и так 'ложится' при ошибке и его нужно перезапускать. Во вторых, ошибка очень странная, такое обычно бывает когда ресурсов ПК не хватает на вовремя закрытие сессии. Можете указать в функции "on shutdown" закрытие сессии бд "session maker"-a (это будет как действие при экстренных случаях)
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
огонь! я вот заметил особенность: весь проект в функциональном стиле, а фильтры и мидлвары в ООП. Чем обусловлен такой подход?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Где что удобнее... Фильтры и прочее удобнее и проще в классах, а хендлеры и прочее удобнее в функциях (когда это свой проект - делаешь так как это удобнее самому). Классы для всего - это не панацея, а зачастую лишь требование загнанного в угол руководителя проекта, а отсюда и стереотипы)))
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
@@PythonHubStudio пасиб ) и еще вопрос с 14й минуты (возможно дальше будет ответ... кто знает) мидлвар, прописанный в admin_router.message.middleware(CounterMiddleware()) увеличивает счетчик при любом обращении к admin_router, а выводит на экран результат только при Delete Product. Хотя в декораторе @admin_router.message(F.text == "Delete Product") тоже фильтрация происходит. Есть ли какой то способ навешивать мидлвар на конкретную функцию, а не на весь роутер?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Нет, только на роутер - до или после фильтров
@serjioautoexec4092
@serjioautoexec4092 3 ай бұрын
Ну да , можно упростить в разы на классах, потом легче переносить в другие проекты. Ассемблер напоминает 😊, взять это копировать туда гоу-ту джамп😊
@eamarc
@eamarc 4 ай бұрын
а где можно посмотреть про стандарт наименования таблиц как существительных в единственном числе? Мне вот только во множественном попадались. Т.е. запросы типа SELECT * FROM products; и дальше каждая запись мапится на product, что в принципе логично...
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Погуглить, но дело в том, что можно и во множественном числе, но негласное соглашение стараться делать в единственном числе, ведь записи в таблице описывают продукт, и чтоб не путаться с -s или без -s, при работе с таблицами, есть негласное правило product а не products
@platon_bassist
@platon_bassist 20 күн бұрын
Здравствуйте. Подскажите - какой код должен быть написан в файле "my_base.db"? Заранее благодарен.
@PythonHubStudio
@PythonHubStudio 19 күн бұрын
Никакой, это файл базы данных (хранилище) для хранения информации
@ustoz_shogird5699
@ustoz_shogird5699 4 ай бұрын
Здравствуйте! На аиограм диалог есть видео уроки?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Как вы могли заметить - нет. Будут ли? Вряд-ли, так как фреймворк поверх другого фреймворка ничего хорошего не несёт...(мое мнение). Это если вы имеете ввиду библиотеку по упрощённому созданию диалогов, а не "комнаты" aiogram.
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
день вопросов продолжается) как решить проблему, когда flake8 ругается на load_dotenv(find_dotenv()) между импортами ?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Можно отключить уведомление о конкретной стилистике. Так писать - нормально, так как подгрузка переменных из окружения должна быть до импорта модуля где создаётся engine. Варианты: 1) Сделать реформат проекта в сторону усложнения для того чтоб использовать подгрузку переменных после имплртов. 2) отключить уведомления от этого уведомления 3) игнорировать
@ivanshinkevich974
@ivanshinkevich974 3 ай бұрын
здравствуйте, у меня проблема: Telegram server says - Bad Request: can't parse entities: Unexpected end tag at byte offset 82
@xjpfxei
@xjpfxei 3 ай бұрын
Получается что на каждый клик по кнопке или сообщению открывается новая сессия? А если там будет тысяча кликающих и пишущих пользователей?
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Вы очень тонко подметили, я этого не сказал в видео. Поверхностно это так и выглядит, но sqlalchemy сформирует, так называемый, пул транзакций, если они однотипные, и выполнит одно обращение к бд. Суть: 1) 100 пользователей единовременно запросили главную страницу 2) Формируется 100 одинаковых сессий в орм 3) Они объединяются в один запрос (реальную одну сессию по работе с бд), которая выполняет единовременную множественную вставку/обновление/выборку из бд.
@bahromgafforov9444
@bahromgafforov9444 3 ай бұрын
сделаем скидка 3.00 -> 2.99 ))
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
😅
@Fankaipon
@Fankaipon 4 ай бұрын
Как сделать бота, которого можно было бы добавить в чат, чтобы бот считал сообщения пользователей и за каждые 50 сообщений давал 5 к балансу пользователя в боте
@antonstoliarenko2445
@antonstoliarenko2445 4 ай бұрын
Курс супер. Но есть вопрос)) код разбит по модулям. В юзер Приват основной код. Но в моем случае в одной из функций сценария нужно вызвать методы бота: dowload , get_file. Я эту функцию вынес в main, но из-за этого и всё остальное пришлось переместить, потому что как мне показалось , логика сценария из-за такого переноса тоже страдает. Можно это как- то исправить?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Как я говорил в этом плейлисте - если нужны методы бота в хендлере, просто добавьте параметр bot: Bot, и экземпляр бота пробросится в хендлер: И юзайте в хендлере методы бота await bot....
@antonstoliarenko2445
@antonstoliarenko2445 4 ай бұрын
Действительно) спасибо!! Еще такой вопрос: может ли быть одновременно несколько состояний FSM? Понимаю что это просто другой класс(ы) и не должно быть с этим проблем, но не будет ли конфликта в сценарии?
@Kovryzhkin
@Kovryzhkin 4 ай бұрын
@PythonHubStudio Может можете помочь с вопросом по Middleware? На основе ваших замечательных уроков делаю корпоративный бот и хочу не пропускать в бот тех, кого ещё нет в корп группе. За счёт фильтров мне все понятно, но хочется за счёт внешнего Middleware. И так, и сяк, но упёрся в пень. И не Ai, не Google не помогают. Может ваш светлый, чистый ум и открытое сердце помогут? 😊
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
В методе call мидлвари ДО вызова handler(event, data) заберите из TelegramObject или Message id юзера, и потом по аналогии как мы делали с админами в хендлере, только экземпляр бота возьмите из словаря data и используйте метод бота get chat members (вроде так называется), и просто проверьте, если user id в списке участников группы по id, то только тогда пускать дальше, то есть вызывать handler (event, data)
@Kovryzhkin
@Kovryzhkin 3 ай бұрын
​@@PythonHubStudioОгромное спасибо. Все вышло. Теперь у меня есть закрытый бот для нужд компании
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Отлично!👍, рад что все получилось!!!
@user-gu1eo9oy1y
@user-gu1eo9oy1y Ай бұрын
Привет , подскажите почему в класс Base не передать id ? Он же тоже будет у всех классов
@PythonHubStudio
@PythonHubStudio Ай бұрын
Можно
@sufferingtheshadow
@sufferingtheshadow 3 ай бұрын
Здравствуйте, повторял всё как в видео, но в конце возникла ошибка при подключении postgresql. Просмотрел на дебаггере, проблема возникает при создании движка. При выполнении строки await conn.run_sync(Base.metadata.create_all), открывается файл библиотеки, как я понял, connect_utils, в ней выполняется функция async def __connect_addr, В которой выполняется условие try: await connected и код завершает работу на куче ошибок. В чём может быть проблема? Использую Windows 10 x64.
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Эта информация, к сожалению ни о чем (не говорит о проблеме, не те выдержки прислали)... Для начала проверьте: 1) установлена и работает ли служба PostgreSQL 2) установлен ли asyncpg 3) правильный ли пароль итд указан
@BEGovoy_DZEN
@BEGovoy_DZEN 2 ай бұрын
Здравствуйте, не вылазит меню после ввода /admin как на видео на 42-й минуте, ошибок никаких нет, в терминале всё как у вас показывает, но вот меню нет. Сначала в группу вбил /admin подтянул админов, а потом уже боту написал, но ничего. Проверил код admin_private.py там всё нормально, слепил из скраншотов видео весь этот файлик, сверил всё идентично. Подскажите в каком файле ещё может быть ошибка. До этого проверка бота была, всё получилось, застрял на 42 минуте.
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
По описанию не могу сказать что не так. Сверьтесь с гитхабом урока.
@AndreyLyamkin
@AndreyLyamkin 2 ай бұрын
Доброго дня! Подскажите, пожалуйста, как можно изменить код, чтобы в конце FSM отправлять данные не в чат с админом, а в другую группу? т.е. не await message.answer(str(data)) что-то в виде: await bot.send_message(chat_id,str(data))
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
Вы все правильно написали (метод через bot). В чем именно проблема?
@AndreyLyamkin
@AndreyLyamkin 2 ай бұрын
@@PythonHubStudio ну вот не могу правильно дописать в Вашем примере. Задача: чтобы отправить все данные в «data” не пользователю, а в админский чат
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
await bot.send_message(admin_id, str(data)) Или так как у нас есть список админов на экземпляре бота, то можно и так: await bot.send_messages(bot.admins_list, str(data)) ^ (множественная рассылка по списку id)
@AndreyLyamkin
@AndreyLyamkin 2 ай бұрын
@@PythonHubStudio мне кажется я так писал. Проверю сейчас
@AndreyLyamkin
@AndreyLyamkin 2 ай бұрын
@@PythonHubStudio все получилось, ошибка была в том, что я не передавал bot в хендлере... спасибо
@g-man7112
@g-man7112 4 ай бұрын
Здравствуйте, вроде бы написал код как у Вас, но в админ приват при попытке записи данных в базу данных выдаёт ошибку: KeyError 'image', подскажи пожалуйста что это может быть.(я пишу код в пайчарме) Спасибо! (изменено) ещё есть ошибка "in call return await handler(event, data)" не знаю какая из них главная и вызывает вторую
@user-yg1xt8cb5n
@user-yg1xt8cb5n Ай бұрын
У меня такая же ошибка, только с кейеррор: description
@Anatolik_live
@Anatolik_live 19 күн бұрын
Здравствуйте! Решили проблему?
@user-tb9vw5ov3j
@user-tb9vw5ov3j 4 ай бұрын
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 4 ай бұрын
Скиньте сюда код метода init мидлвари и строку где он регистрируется
@glvd3960
@glvd3960 4 ай бұрын
​@@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 4 ай бұрын
В самом методе call все нормально. Зачем символ декоратора @ в регистрации мидлвари? Просто через объект роутера нужно
@SeDiSlayer
@SeDiSlayer 3 ай бұрын
Тоже столкнулся с этой ошибкой, полез гуглить, добавил аргументы и поймал следующую ошибку... Все делал как в видео. Единственное отличие, 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 3 ай бұрын
Сори, нашел ошибку. Не внимательный, потерял скобки.
@valerijt4344
@valerijt4344 2 күн бұрын
Заметил, что на aiogram 3.7 не работает форматирование подписей под фото.. Пица Пица
@PythonHubStudio
@PythonHubStudio 2 күн бұрын
Там изменили "место" где нужно указывать метод форматирования (рефакторинг пакетов сделали). Посмотрите в документах "formatting". И никогда не спешите обновлять версии) Видео на 3.3.0, поэтому такие моменты возможны
@icrypter
@icrypter 4 ай бұрын
+
@nikiost6707
@nikiost6707 3 ай бұрын
у меня почему-то наоборот вылетает миллиард ошибок после того как подключил базу данных, причем ошибки не схожие вообще
@catstyle1101
@catstyle1101 4 ай бұрын
Если будут править разные карточки два админа одновременно, то будет любопытный результат.
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Да, это не предусмотрено
@user-wb9wn6vy4g
@user-wb9wn6vy4g 4 ай бұрын
Привет! Подскажите что не так- 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 4 ай бұрын
разобрался в чем проблема была? а то у меня тоже она выскочила!!
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Url адрес (строка базы данных) не просчиталась из файла .env, os.getenv вернул None, потому что нет переменной указанной в нем (опечатка). Можете там просто как строку url-ку записать
@user-kx1wv2uy9m
@user-kx1wv2uy9m 4 ай бұрын
@@PythonHubStudio не поверите, но сегодня запустил опять Ваш код и все заработала без ошибок. Магия в общем )) все загружает в постегр и базы формирует. Спасибо за урок, жду с нетерпением продолжения :)
@DataFlex_Studio
@DataFlex_Studio 2 ай бұрын
Подскажите пожалуйста, столкнулся с проблемой... VS Code не всегда предлагает варианты исправления кода как у автора в этом видео. Например на 38:15 "session_maker" подчеркнут желтой линией и Quick Fix предложил вариант с импортом для исправления. Дак вот у меня в этом месте ничего не предлагает исправить, можно только посмотреть проблему. И много таких ситуаций было в течение курса, но иногда все же предлагает варианты для исправления. Quick Fix в настройках везде включен, в расширениях Python установлен последней версии, VS Code так же обновлен до последней версии. Работаю на Mac OS M1. Спасибо всем кто поможет) Я новичок и эта фишка очень помогла бы мне)
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
Проект открыт нормально в редакторе? Или вы открыли папку с этим и кучей других проектов?
@user-tu5un1dr2m
@user-tu5un1dr2m 2 ай бұрын
ругается на строчки импорт датабейс, хотя вроде все точно так же как у вас, помогите пожалуйста?
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
Возможно проект открыт в редакторе на директорию выше чем положено.
@Rasulov_Shop
@Rasulov_Shop 4 ай бұрын
Алхимия как смысл жизни 😂
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Все хотят изобрести "философский камень")))
@odin_gaming
@odin_gaming 3 ай бұрын
не могу решить никак проблему по добавлению фото. выбивает в терминале ошибку: "TypeError: add_image() missing 1 required positional argument: 'session'". Я уже даже твой код скопировал с гитхаба и все равно таже ошибка, даже с твоим кодом. В чем может быть проблема?
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
А сессию первым аргументом передаёте в add_image(session, ...) ?
@odin_gaming
@odin_gaming 3 ай бұрын
​@@PythonHubStudio попробовал первым вот так: async def add_image(session, message: types.Message, state: FSMContext): и уже пишет что TypeError: add_image() missing 1 required positional argument: 'message'
@odin_gaming
@odin_gaming 2 ай бұрын
если у кого будет подобная проблема. то вот что мне помогло: импортируйте from database.engine import session_maker и потом начинайте функцию вот так: async def add_image(message: types.Message, state: FSMContext): async with session_maker() as session: тут остальное без изиенений
@user-kx1wv2uy9m
@user-kx1wv2uy9m 4 ай бұрын
Доброго времени суток. Подскажите плиз при попытке изменения товара в ассортименте, а именно сохранении описания (путем ввода точки в сообщение телеграмм-боту) выдает ошибку 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 4 ай бұрын
Хм... А исходник с GitHub работает?
@user-kx1wv2uy9m
@user-kx1wv2uy9m 4 ай бұрын
@@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 4 ай бұрын
Видел вопрос решился)
@SpEvgeniy
@SpEvgeniy Ай бұрын
@@PythonHubStudio , привет, не нашел как вопрос решился?, тоже пишу сам, такое ощущение, что product_for_change как то коряво создается... upd: Ну так и есть , начал проверять запрос в базу , по итогу в orm_get_product, указал неверный return - result.scalars(), по итогу поправил на scalar() и все завелось. Вдруг кому пригодится!
@vincentvega1391
@vincentvega1391 2 ай бұрын
Как задонатить?
@user-ro8iq2kd7w
@user-ro8iq2kd7w 3 ай бұрын
Автор доброго времени суток. У меня на сервере установлено MySQL Mariadb и клиент phpmyadmin Mariadb как в таком случае подключаться подскажите?
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Погуглите: sqlalchemy для асинхронной MySQL. Будет примерно так: mysql+asyncmy://login: password@localhost/dbname
@user-ro8iq2kd7w
@user-ro8iq2kd7w 3 ай бұрын
@@PythonHubStudio спасибо большое. Продолжение будет видео уроков с инструкциями? Учусь, записываю основные моменты
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Следующий видик уже есть, дальше не знаю, буду делать продолжение или нет...
@HetrateHetrate
@HetrateHetrate 3 ай бұрын
@@PythonHubStudioделайте обязательно, это единственный ролик на ютубе где я нашел как прокинуть скл алхими и сессии через мидлварь а не через глобальную сессию на ютубе! Очень хороший и качественный контент.
@user-ld6ss8hi8v
@user-ld6ss8hi8v 4 ай бұрын
Здравствуйте. Появилась проблема (не появляется файл my_base.db, нет самого приложения с базой данных). Код вроде проверил все верно. Как решить такую проблему?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Ошибку отображает? Если нет, обновите експлорер файлов в редакторе, если есть ошибка, то рассмотрите ее, или пришлите сюда, посмотрим
@user-ld6ss8hi8v
@user-ld6ss8hi8v 4 ай бұрын
​@@PythonHubStudio, никаких ошибок нет. В терминале вылазит вывод sql-запросов. VS Code перезагружал. Файла все равно нет
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Если вылазит вывод sql запросов, то значит все работает правильно, но!, обратите внимание на то как именно вы открыли проект и как его запустили. Файл my_base.db будет в той папке, где запускается терминал в редакторе. Просто в редакторе откройте терминал (terminal> new terminal) и посмотрите какой там указан путь. Суть в том, что проект нужно открывать в редакторе так, чтоб открыть папку в которой app.py, и тогда все будет на своем месте
@user-ld6ss8hi8v
@user-ld6ss8hi8v 4 ай бұрын
​​@@PythonHubStudio, благодарю вас за помощь. Действительно помогло. Но приложение так и не нашёл.
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Тут я не понял, сначала пропустил, думал это оборот речи, НО какое приложение имеется ввиду? Если вы имеете ввиду DB Browser (SQLite), то его нужно скачать из интернета, не с какого-то там сайта-агрегатора программ, а с их официального: на всякий случай вот ссылка, где я ее скачал: sqlitebrowser.org/
@diverse3318
@diverse3318 16 күн бұрын
Здравствуйте. Что делать, если я копирую весь ваш код, который выложен на GitHub, но у меня все равно ничего не работает? В терминале просто очень много каких-то ошибок: Traceback (most recent call last): File "G:\pycharm projects\pythonProject\app.py", line 13, in from database.engine import create_db, drop_db, session_maker File "G:\pycharm projects\pythonProject\database\engine.py", line 12, in engine = create_async_engine(os.getenv('DB_URL'), echo=True) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "G:\pycharm projects\pythonProject\.venv\Lib\site-packages\sqlalchemy\ext\asyncio\engine.py", line 120, in create_async_engine sync_engine = _create_engine(url, **kw) ^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create_engine File "G:\pycharm projects\pythonProject\.venv\Lib\site-packages\sqlalchemy\util\deprecations.py", line 281, in warned return fn(*args, **kwargs) # type: ignore[no-any-return] ^^^^^^^^^^^^^^^^^^^ File "G:\pycharm projects\pythonProject\.venv\Lib\site-packages\sqlalchemy\engine\create.py", line 546, in create_engine u = _url.make_url(url) ^^^^^^^^^^^^^^^^^^ File "G:\pycharm projects\pythonProject\.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
@valerijt4344
@valerijt4344 3 күн бұрын
Добрый день! я тоже с этой ошибкой столкнулся. Вы ее победили?
@diverse3318
@diverse3318 3 күн бұрын
@@valerijt4344 нет
@PythonHubStudio
@PythonHubStudio 3 күн бұрын
Нужно подключить базу данных. Именно об этом и говорит ошибка
@valerijt4344
@valerijt4344 2 күн бұрын
@@PythonHubStudio спасибо за обратную связь. причина была еще банальней: 1) сначала было вот-так "sqlite+aiosqlie", а нужно "sqlite+aiosqlite" 2) дальше проявилась еще одна особенность алхимии, что она не подтягивает для mac_M1 модуль greenlet, и его нужно установить руками.
@creativejuices91
@creativejuices91 Ай бұрын
подскажите пожалуйста как быть без dotenv, он не устанавливается, пришлось просто через конфиг, но тогда файл базы не создаётся
@PythonHubStudio
@PythonHubStudio Ай бұрын
url бд тоже из конфига берите, или установите другую библиотеку для работы с env файлами (их много)
@creativejuices91
@creativejuices91 Ай бұрын
спасибо. я просто через pip3 установил. Но всё равно не создаётся файлик. так то ошибок нет. И принтит "бот лёг"
@creativejuices91
@creativejuices91 Ай бұрын
@@PythonHubStudio в чём может быть проблема?
@creativejuices91
@creativejuices91 Ай бұрын
с этим тоже разобрался уже. Но вот файлик реально не создаёт
@creativejuices91
@creativejuices91 Ай бұрын
нашёл. она почему в pythonprojects создалась
@BoAnMi
@BoAnMi 3 ай бұрын
хьюстон, у меня проблема) не удается разрешить импорт kbds.inline, запускал через venv, даже установил версию python 3.11.1, не помогло, было у кого нибуть такое? гугол молчит на эту проблему
@PythonHubStudio
@PythonHubStudio 3 ай бұрын
Не тот файл возможно запускается, нужно запускать app.py. Причины: 1) В прямом смысле запускаете скрипт не с файла app.py 2) После смены папки проекта не создали новый config для "нового" проекта 3) В pycharm тыкнуть правой кнопкой мыши по папке, где лежит app.py и выбрать "пометить как папку проекта"
@BoAnMi
@BoAnMi 2 ай бұрын
@@PythonHubStudio сам накосячил, букву перепутал в названии папки) неделю искал проблему🤣
@PythonHubStudio
@PythonHubStudio 2 ай бұрын
😅норм)
@user-yw7hd8qr1v
@user-yw7hd8qr1v Ай бұрын
не совсем понятно, что такое handler в middleware
@PythonHubStudio
@PythonHubStudio Ай бұрын
Это объект который заботиться о последующей распаковке данных апдейта из json в формат класса python типа Message, Callback и тд. Это внутренняя структура фреймворка и особо париться не нужно на этот счёт
@user-yw7hd8qr1v
@user-yw7hd8qr1v Ай бұрын
@@PythonHubStudio спасибо!
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 4 ай бұрын
Уважаемый автор, у меня есть канал на ютубе. Не такой большой как у Вас и немного на другую тему. Я создал бота для помощи водителям на дороге и планирую его усовершенствовать. Сможете помочь?
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
Извините, но дел и так очень много... С личным проектом не помогу.
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 4 ай бұрын
@@PythonHubStudio если Вы водитель, то это может бесплатно помочь и Вам))) мне нужна элементарная помощь...бот человеку задает некие вопросы, получает ответы, где-то их собирает и в итоге данные из ответов вставляет в pdf файл и отправляет обратно пользователю
@musoroszhigayschiy_zavod76
@musoroszhigayschiy_zavod76 4 ай бұрын
ну если не получится, то извините)))
@evgen3
@evgen3 Ай бұрын
У вас что-то с микрофоном не так.Местами по ушам бьет
@PythonHubStudio
@PythonHubStudio Ай бұрын
Приму во внимание!
@borisp9625
@borisp9625 27 күн бұрын
пробовал переделать функцию удаления строки чтобы работала универсальна, передавать название таблицы , table_name = 'company' query2 = text(f"SELECT * FROM {table_name}") query = select(Company) result = await session.execute(query) result = await session.execute(query2) Получается разный результат, в первом случаи возвращает result во втором cursor что надо дописать чтобы работало?
@iceongone4490
@iceongone4490 3 ай бұрын
@IvaschenkoN
@IvaschenkoN 4 ай бұрын
куда то пропал мой последний коммент. 1. зачем в админ приват в строке @admin_router.message(AddProduct.name, or_f(F.text, F.text == '.')) условие or_f ? ведь точка входит в множество F.text 2. как и ожидалось при добавлении нового товара с точкой вместо имени - код крашится. нужно обработать
@PythonHubStudio
@PythonHubStudio 4 ай бұрын
1) это пример, ведь первое условие не обязательно F.text может быть 2) Да, нужно добавить проверку, это ведь не сложно сделать
@creativejuices91
@creativejuices91 Ай бұрын
подскажите пожалуйста кто-то. Бьюсь уже не первій день с этим. @admin_router.callback_query(F.data.starswith('delete_')) эта строчка не отлавливает дату. То есть ошибок нет никаких. При создании кнопок дата сохраняется(я принтил, проверял). Но дохожу до этого хэндлера - ничего не работает, не удаляется товар
@creativejuices91
@creativejuices91 Ай бұрын
Охрана отмена! только что понял, в startswith букву t пропустил. Интересно, что ошибку не выбило
@PythonHubStudio
@PythonHubStudio Ай бұрын
😅
Increíble final 😱
00:37
Juan De Dios Pantoja 2
Рет қаралды 90 МЛН
PINK STEERING STEERING CAR
00:31
Levsob
Рет қаралды 21 МЛН
Haha😂 Power💪 #trending #funny #viral #shorts
00:18
Reaction Station TV
Рет қаралды 7 МЛН
Sprinting with More and More Money
00:29
MrBeast
Рет қаралды 184 МЛН
Alembic - Как делать Миграции Базы Данных на Python #13
14:58
КАК СОЗДАТЬ СВОЙ САЙТ С НУЛЯ ● ПРОСТО О HTML И CSS 2020 ● #1
6:40
Ranch Easy | Информатика ЕГЭ
Рет қаралды 10 М.
Increíble final 😱
00:37
Juan De Dios Pantoja 2
Рет қаралды 90 МЛН