Форум программистов, компьютерный форум, киберфорум
Python: API, боты
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146

Правильные действия если еще не был нажат Start, но запущена другая команда из меню бота

20.06.2022, 13:19. Показов 566. Ответов 2

Студворк — интернет-сервис помощи студентам
Всем доброго дня!
Использую aiogram
Хочу понять, как грамотно выстроить логику - предположим, у меня в меню команд есть три команды, добавляю их в коде:
Python
1
2
3
4
5
6
async def on_startup(dispatcher: Dispatcher) -> None:
    await bot.set_my_commands([
        types.BotCommand("start", "start bot..."),
        types.BotCommand("help",  "help..."),
        types.BotCommand("settings", "some personal settings...")
    ])
Далее, в команде "start" я делаю некоторую первичную инициализацию, привязанную именно к юзеру(поднимаю данные юзера из БД и т.д.) и показываю кнопки главного меню бота. В команде "settings" я даю юзеру возможность ввести какую-то персональную инфу, для этого даю ему другие кнопки. А теперь предположим, что я рестартовал бота, соответственно в памяти все обнулилось. Юзер об этом не знает, но решил сначала подправить свою персональную инфу и сначала жмет "settings". А у меня первичная инициализация(для данного юзера) еще не прошла, она привязана к команде Старт.
И здесь у меня есть два выхода. Первый - если юзер еще НЕ заводил Старт, то сообщить ему, чтобы сначала сделал Старт. Решение так себе, не очень красивое, ИМХО. Выход второй - определить, что первичная инициализация еще не сделана, сделать тихо данную инициализацию, и продолжить как ни в чем не бывало, т.е. показать юзеру кнопки для "settings". И работать как обычно. Если же юзер захочет увидеть кнопки главного меню, то он сам догадается, что надо все-таки завести Старт.
Еще немного кода для наглядности (псевдокод):
Python
1
2
3
4
5
6
7
8
9
10
11
12
@dp.message_handler(commands="start", state="*")
async def start_menu(message: types.Message):
    init_some_data_from_DB(message.from_user.id)
    await bot.send_message(message.from_user.id, 'Welcome to uor bot!', reply_markup=keyboard_start)
    await FSMAdmin.Start.set()
 
@dp.message_handler(commands="settings", state="*")
async def settings_menu(message: types.Message):
    if not data_initiated(message.from_user.id):
        init_some_data_from_DB(message.from_user.id)
    await bot.send_message(message.from_user.id, 'Please set/change your personal info:', reply_markup=keyboard_settings)
    await FSMAdmin.Settings.set()
Вопрос к знающим - какие есть общепринятые решения по теме?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.06.2022, 13:19
Ответы с готовыми решениями:

Как запустить форму если она ещё не запущена?
нужно запустить форму если она ещё не запущена

Проверка запущена ли другая программа
Нужно написать две проги:первая пустая,вторая сканит на наличие запущеной первой и если таковая запущена выводит текст,если нет-...

если .click один - одна функция, .click еще раз и другая
как сделать чтоб она проверило .click первый и если он выполнен, то уже при втором клике, выполнялась другая функция Добавлено через...

2
Модератор
Эксперт Python
 Аватар для Fudthhh
2696 / 1602 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
20.06.2022, 14:12
Цитата Сообщение от vkiper Посмотреть сообщение
что я рестартовал бота, соответственно в памяти все обнулилось
Что мешает хранить данные в БД?

Цитата Сообщение от vkiper Посмотреть сообщение
И здесь у меня есть два выхода
В любом случае стоит объяснить пользователю что произошло, и попросить выполнить определенные действия.
Допустим если пользователь вводит адрес доставки, то какое значение по умолчанию ты выставишь?

Цитата Сообщение от vkiper Посмотреть сообщение
то он сам догадается
Тут поспорю, всем разработчикам кажется их код и ход мыслей логичными, но пользователи разные бывают.

Из жизни: При операции считывания с устройства данных у меня было две кнопки, считать и закрыть диалог. Пользователь был в недоумении, почему когда он закрывает диалог, чтение прерывается, как он должен был догадаться об этом?
1
17 / 17 / 6
Регистрация: 11.11.2015
Сообщений: 146
20.06.2022, 14:58  [ТС]
Идея понятна, спасибо. Буду копать туда.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.06.2022, 14:58
Помогаю со студенческими работами здесь

Какой из компонентов был нажат?
в общем есть массив изображений, который создаётся так: setlength(image_array,4); for i:=0 to length(image_array)-1 do for...

Написать программу, следящую, чтобы другая была всегда запущена
Нужно сделать код какой будет работать в таком принципе. 1. Проверяется запущены такие программы. Указанное мною имя.exe Указанное...

Как узнать какой submit был нажат?
Привет! На моей форме несколько кнопок submit Как узнать name той, что была нажата. Заранее благодарна :)

Отследить, какой элемент управления был нажат
Доброе день) Не подскажите ?Хочу отследить какие элементы управления были нажаты. Вот например "Button", "CheckBox",...

Нужно узнать какой input был нажат
значит вопрос такой: допустим,что у нас есть 10 <input type="text" name="..." readonly> Как можно при нажатии на один или другой узнать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru