Форум программистов, компьютерный форум, киберфорум
Python: API, боты
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 16.04.2023
Сообщений: 3
Telegram Bot

Телеграм-бот: не отображается информация из бд

16.04.2023, 07:17. Показов 1172. Ответов 5

Студворк — интернет-сервис помощи студентам
Пишу Телеграм бот первый раз, который выводит в inline-кнопки факультеты из бд SQLite, а после выбора факультета должен выводить также в inline-кнопки направления из бд, которые есть на этом факультете. Вот фрагмент кода, но он не выводит то, что нужно. Помоги очень срочно
Библиотека pytelegrambotapi

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
def get_directions(faculty):
    cur.execute("SELECT direction FROM directions WHERE faculty = ?", [faculty,])
    directions = cur.fetchall()
    return directions
 
def send_directions(callback_query, faculty):
    directions = get_directions(faculty)
    mark_dir = types.InlineKeyboardMarkup()
    for direction in directions:
        mark_dir.add(types.InlineKeyboardButton(text=direction[2],callback_data=f'dir:{direction[2]}'))
    bot.send_message(callback_query.message.chat.id,
        f"Выберите направление на факультете {faculty}:", reply_markup=mark_dir)
 
@bot.callback_query_handler(func=lambda call: True)
def get_info(call):
    ...
    elif call.data == "fac":
        send_directions(call, call.message.text)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.04.2023, 07:17
Ответы с готовыми решениями:

Телеграм бот, создающий телеграм ботов с определёнными функциями
Подскажите,пожалуйста, как возможно написать телеграм бота, создающего другого тг бота на основе токена, который пользователь пошлёт. Каким...

Телеграм-бот
Добрый день! Возникло желание создать телеграм-бот интеллектуальную игру. Бота создала, а с чего начать игру не понимаю. Суть такая -...

Телеграм Бот
Доброго времени суток!!! возникла проблема при создании бота в телеграм на языке Python 3, при помощи библиотеки "telebot" ...

5
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,306
16.04.2023, 11:02
У Вас с faculty какая-то беда, видимо как-то криво обрабатываете нажатие предыдущих кнопок.
Цитата Сообщение от Ru4ka Посмотреть сообщение
f"Выберите направление на факультете {faculty}:", reply_markup=mark_dir)
На практике выводит "Выберите направление на факультете Выберите факультет::" и соответственно селект ничего не возвращает.
0
0 / 0 / 0
Регистрация: 16.04.2023
Сообщений: 3
16.04.2023, 16:56  [ТС]
Да, понимаю. Но прям не вижу, где именно проблема, почему кнопки не хотят выводятся из бд
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,306
16.04.2023, 19:12
В кнопки с факультетами названия факультетов нужно передавать в callback_data, оттуда же и их тянуть при передаче в другой обработчик.
Цитата Сообщение от Ru4ka Посмотреть сообщение
send_directions(call, call.message.text)
Python
1
2
3
send_directions(call, call.data)
# Либо
send_directions(call, call.data[x:y]) # если нужно использовать часть callback_data
0
0 / 0 / 0
Регистрация: 16.04.2023
Сообщений: 3
17.04.2023, 05:18  [ТС]
Почему-то по-другому передать информацию в "callback_data='fac'" не получается, только так работает, а иначе появляются ошибки, что размер превышен. Если, например, аналогично написать, как "callback_data=f'dir:{direction[2]}'"
Заранее спасибо за помощь, просто уже все перепробовала. И из-за отсутствия опыта прям в тупике сейчас

Так выглядит inline-кнопки с факультетами
Python
1
2
3
4
5
6
7
8
9
def get_faculties():
    cur.execute('SELECT DISTINCT faculty FROM directions')
    faculties = cur.fetchall()
    return faculties
 
faculties = db.get_faculties()
mark_fac = types.InlineKeyboardMarkup()
for faculty in faculties:
    mark_fac.add(types.InlineKeyboardButton(text=faculty[0], callback_data='fac'))

send_directions(call, call.data)
такой результат получается
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,306
17.04.2023, 12:06
Крайне топорный вариант:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def get_button_text(obj):
    for b in obj.json['message']['reply_markup']['inline_keyboard'][0]:
        if b['callback_data'] == obj.data:
            return b['text']
 
def get_faculties():
    cur.execute('SELECT DISTINCT faculty FROM directions')
    faculties = cur.fetchall()
    return faculties
 
faculties = db.get_faculties()
mark_fac = types.InlineKeyboardMarkup()
for i, faculty in enumerate(aculties):
    mark_fac.add(types.InlineKeyboardButton(text=faculty[0], callback_data=f'fac:{i}'))
 
def get_info(call):
    ...
    elif 'fac' in call.data:
        send_directions(call, get_button_text(call))
Более правильный вариант изучать норальные формы в БД и переходить на работу с первичными ключами.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.04.2023, 12:06
Помогаю со студенческими работами здесь

Телеграм-бот
Скачал я бота, а он с ошибками, или просто на виндовс не работает. В общем помогите: Код бота: #!/usr/bin/python3.4 # -*- coding:...

телеграм бот
При нажатии на кнопку гороскоп или погода ничего не происходит. 3 день ищу информацию в гугле и не могу понять решение этой проблемы. ...

Телеграм бот
помогите разобраться с кодом для телеграмм бота при запуске выявляется много ошибок

Телеграм Бот
Всем привет. Пытаюсь писать телеграм бота, застрял на одном моменте. Как поочередно задавать вопросы пользователю и запоминать ответы? К...

Телеграм бот
Здравствуйте, возможно это глупый вопрос,но недавно начал изучать python. Узнал что с помощью его можно сделать бота в телеграме. И так как...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru