Python client (unofficial) for MAX API. Early version
Project description
Maxgram
v0.1.4 от 29.03.2025
https://pypi.org/project/maxgram/
Python-клиент (неофициальный) для API MAX
Внимание! Разработка в ранней стадии. Сейчас поддерживаются: прием и отправка сообщений, инлайн-кнопки.
Обсудить в MAX DevChat - комьюнити разработчиков ботов и приложений MAX
Быстрый старт
1. Установка
pip install maxgram
если нужно обновление, то
pip install maxgram --upgrade
2. Получение токена
Откройте диалог с MasterBot, следуйте инструкциям и создайте нового бота. После создания бота MasterBot отправит вам токен. Используйте его в коде ниже вместо YOUR_BOT_TOKEN
3. Пример эхо-бота
from maxgram import Bot
# Инициализация бота (рекомендуется получать через .env)
bot = Bot("YOUR_BOT_TOKEN")
# Обработчик события запуска бота
@bot.on("bot_started")
def on_start(context):
context.reply("Привет! Отправь мне ping, чтобы сыграть в пинг-понг или скажи /hello")
# Обработчик для сообщения с текстом 'ping'
@bot.hears("ping")
def ping_handler(context):
context.reply("pong")
# Обработчик команды '/hello'
@bot.command("hello")
def hello_handler(context):
context.reply("world")
# Обработчик для всех остальных входящих сообщений
@bot.on("message_created")
def echo(context):
# Проверяем, что есть сообщение и тело сообщения
if context.message and context.message.get("body") and "text" in context.message["body"]:
# Получаем текст сообщения
text = context.message["body"]["text"]
# Проверяем, что это не команда и не специальные сообщения с обработчиками
if not text.startswith("/") and text != "ping" and text != "hello":
context.reply(text)
# Запуск бота
if __name__ == "__main__":
try:
bot.run()
except KeyboardInterrupt:
bot.stop()
4. Установка подсказок для команд бота
# Установка команд бота
bot.set_my_commands({
"help": "Получить помощь",
"ping": "Проверка работы бота",
"hello": "Приветствие"
})
Примечание: функционал подсказок сейчас может не работать на десктопном клиенте
5. Работа с клавиатурой
- Полный пример смотрите keyboard_bot.py
Создание клавиатуры
- Поддерживаются инлайн-кнопки, иимпортируйте InlineKeyboard из библиотеки
- Для формирования клавиатуры передайте списки, где каждый список - это одна строка кнопок. Внутри строки кнопок располагаются словари с названием и уникальным тегом кнопки. Callback - обычная кнопка, url - кнопка ссылка
- Количество кнопок в строке по количеству словарей. При этом ширина кнопок делится поровну
- Для отправки клавиатуры в сообщении просто передайте параметр keyboard в reply c названием клавиатуры
from maxgram.keyboards import InlineKeyboard
# Создание клавиатуры
main_keyboard = InlineKeyboard(
[
{"text": "Отправить новое сообщение", "callback": "button1"},
],
[
{"text": "Изменить сообщение", "callback": "button2"},
{"text": "Показать Назад", "callback": "button3"}
],
[
{"text": "Открыть ссылку", "url": "https://pypi.org/project/maxgram/"}
]
)
# Отправить клавиатуру по команде '/keyboard'
@bot.command("keyboard")
def keyboard_command(context):
context.reply(
"Вот клавиатура. Выбери одну из опций:",
keyboard=main_keyboard
)
Обработка нажатий на кнопки
- Примите уникальные теги кнопок из .payload и отвечайте с помощью .reply_callback
- Можно передавать новые клавиатуры в сообщениях
- Укажите параметр is_current=True, чтобы изменить текущее сообщение, а не отправлять новое
# Обработчик нажатий на кнопки
@bot.on("message_callback")
def handle_callback(context):
button = context.payload
if button == "button1":
context.reply_callback("Вы отправили новое сообщение")
elif button == "button2":
context.reply_callback("Вы изменили текущее сообщение", is_current=True)
elif button == "button3":
context.reply_callback("Вы изменили текущее сообщение с новой клавиатурой",
keyboard=InlineKeyboard(
[{"text": "Вернуться к меню", "callback": "back_to_menu"}]
),
is_current=True)
elif button == "back_to_menu":
context.reply_callback(
"Вернемся к основному меню",
keyboard=main_keyboard,
is_current=True
)
Больше документации и примеров
-
(в разработке) Документация
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file maxgram-0.1.4.tar.gz.
File metadata
- Download URL: maxgram-0.1.4.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d123d9660561d4b2a696a4430f9ab43c5d9509ee88aaddde6838dc6abf97b1a9
|
|
| MD5 |
193f0170867b5f6168583fff49abbf55
|
|
| BLAKE2b-256 |
580a3fdc74bc750a96ac0650aee54b162f5304fa6f5446d038f6a8b732d57cd0
|