В этой иструкции разберем процесс создания простого бота-ремайндера, единственная задача которого — напоминать пользователю о важных делах. Это базовая конструкция, которую можно усложнять и менять под свои потребности.
Инструкция подойдет для новичков, которые знают Python на базовом уровне, пробовали писать код и установили на компьютер редактор кода.
Первый этап: подготовка проекта и развертывание окружения
Найдем в поиске Telegram BotFather — официального бота мессенджера, который создает другие боты и управляет ими. В интерфейсе выбираем /start, затем — /newbot, и следом задаем имя и адрес. В этой иструкции это будут Elbrus Reminder и elbrus_reminder_bot соответственно.
Переводчик в телеграм
После этого BotFather пришлет сообщение с токеном и ссылкой на бот:
Токен нужно хранить в безопасном месте — он дает контроль над ботом. и, как следствие, позволяет получить доступ к данным пользователей.
На время закроем Telegram и создадим на компьютере папку с именем проекта: например, reminder_bot. Откроем папку в среде разработки и создадим рабочий файл с понятным названием — bot.py.
Откроем терминал редактора кода и создадим для проекта новое окружение. В среде разработки с помощью команды python -m venv .venv создадим папку с окружением .venv .
Если окружение не активировалось автоматически, можно сделать это вручную, прописав путь к файлу активации в формате source .venv/bin/activate , где source — команда языка программирования Bash. Другой вариант — перезапустить среду разработки. Он работает для Visual Studio Code, но нужно предварительно принять предложение редактора привязать среду к папке проекта сразу после создания окружения.
Практика создания нового окружения под каждый проект позволяет повыстить безопасности и стабильность проекта — в окружении вы можете использовать только те библиотеки и их версии, которые требуются в проекте. Если в проекте появятся дополнительные функции, все изменения будут храниться в этом окружении. При этом оно будет изолировано от других окружений и проектов — это повысит безопасность проекта.
Второй этап: подключаем библиотеки
Проект создан и окружение готово: пора переходить к написанию кода. По правилам хорошего тона в первую очередь через import добавляем несколько предустановленных библиотек Python. При создании бота нам пригодятся logging и time , которые отвечают за определение времени и логирование сообщений.
import time import logging
Затем добавим асинхронную библиотеку aiogram, на основе которой будет работать бот. Она, например, определяет, какое сообщение пришло, как его нужно обработать и какие порты нужны. Сначала устанавливаем ее через терминал командой pip install aiogram , а в редакторе кода пишем следующее:
Как перевести текст на телеграмме #shorts #android #telegram
from aiogram import Bot, Dispatcher, executor, types
Из этой библиотеки нам нужны только отдельные модули и классы — все ее возможности для создания базовой версии бота не пригодятся. Поэтому вместо одиночного import использована команда from <> import <> .
Когда библиотеки импортированы, создадим переменные с токеном бота и сообщением, которое он будет отправлять пользователю. Вы можете заменить это сообщение на любое другое, которое вам необходимо. Это статические переменные, поэтому их имена написаны капслоком:
TOKEN = «здесьбудетваштокенот от BotFather» MSG = «Программировал ли ты сегодня, <>?»
Токены, ключи и прочие данные для настройки проекта лучше загружать более безопасным способом (например, создавать переменные окружения или файлы конфигурации). Но в данном случае сделаем все в одном файле для наглядности, а примеры более безопасной работы с такими переменными разберем в следующих постах.
Теперь создадим экземпляр класса Bot , передав ему в качестве аргумента наш токен, и экземпляр класса Dispatcher (dp), который в качестве аргумента получит bot . В результате получаем связку объекта класса bot с ключем, который привязан к боту, и диспетчера, который привязан к этому боту:
bot = Bot(token=TOKEN) dp = Dispatcher(bot=bot)
Следующим шагом добавим конструкцию под названием декоратор ( massage_handler ) — она помогает получить из диспетчера нужный функционал. В качестве аргумента прописываем команды, которые обрабатывает декоратор — в данном случае это команда /start , которая запускает бот.
Под декоратором прописываем функцию, которая будет обрабатывать команду /start и определяет логику, в соответствии с которой будет работать бот. Поскольку мы работаем с асинхронной библиотекой, функция тоже должна быть асинхронной. Для этого перед указанием def добавим ключевое слово async :
async def start_handler(message: types.Message):
Функция приветствует пользователя и обрабатывает сообщение, которое он отправляет в ответ. Из сообщения можно получить информацию о пользователе, который его прислал, время отправки и его ID.
Создаем переменную и сохраняем в ней user id :
user_id = message.from_user.id
Затем получаем из сообщения короткое и полное имя пользователя:
user_name = message.from_user.first_name user_full_name = message.from_user.full_name
Для того, чтобы в логах отображалась информация о пользователе, передаем в виде текста ID и полное имя, а также используем возможности библиотеки time , чтобы определить время, когда писал пользователь:
logging.info(f’ ‘)
Здесь отойдем в сторону и проверим корректность работы модуля time . Сделать это можно в терминале: для этого напишем import time , а затем — time.asctime
Вернемся к коду. Поскольку функция, которую мы используем, асинхронна, вместо обычного для функций return используем await :
await message.reply(f»Привет, !»)
Ответить пользователю в боте можно несколькими способами — в данном случае используем reply. Выше в переменной MSG мы задали стандартное сообщение: «Программировал ли ты сегодня, <>?». Зададим частоту напоминаний: семь раз каждые семь суток (60х60х24 — количество секунд в одних сутках) с момента отправки команды /start боту от пользователя:
for i in range(7): await asyncio.sleep(60*60*24)
Затем настроим отправку сообщения с указанием имени пользователя в этом же цикле:
await bot.send_message(user_id, MSG.format(user_name))
Третий этап: финал
Переходим к финальной части: в конце скрипта напишем несколько строк. Они могут показаться странными для новичка, но это общепринятая практика, к которой многие программисты прибегают при разработке. В этой строке мы проверяем, равна ли переменная __name__ строке «__main__» . Это условие всегда будет True, если мы запускаем этот файл как python-скрипт через терминал:
if __name__ == ‘__main__’:
Теперь делаем нашего бота доступным в сети:
executor.start_polling(dp)
Сохраняем файл. Запускаем бота в терминале, открытом в папке проекта, с помощью команды python bot.py .
Вернемся в BotFather и перейдем по ссылке, которую получили вместе с токеном. Нажимаем «Начать» — готово, бот, написанный меньше, чем в 30 строк, работает.
Так выглядит его код целиком:
В следующий раз подробно расскажем, как написать подобный бот на языке программирования JavaScript. Подписывайтесь, чтобы не пропустить инструкцию.
Источник: tproger.ru
Обзор 5 популярных телеграм ботов в медицине
В эпоху стремительно развивающихся интернет технологий, никого не удивишь искусственным интеллектом или возможностями новомодного смартфона. На сегодняшний день, настоящим открытием является привлечение чат-ботов в отрасль медицины. Клиники создают уникальных виртуальных помощников, найти которых можно в популярном мессенджере Telegram.
Каковы особенности и преимущества ботов?
Растущую популярность телеграмм ботов в медицинской сфере, можно объяснить рядом таких факторов:
- Получение мгновенного ответа на свой запрос
- Онлайн запись к подходящему врачу
- Квалифицированная медицинская помощь, не выходя из дома
- Избежание стресса от похода к врачу
- Экономия времени и абсолютная конфиденциальность
5 популярных телеграмм ботов для врачей и клиник
DR. VIRA
Клиника Into-Sana ввела в свой штат виртуального помощника Dr.Vira, который мгновенно завоевал популярность, благодаря профессиональному подходу и высокой компетентности. Путем обширного онлайн анкетирования, данный бот способен определит наличие предрасположенности человека к той или иной болезни и может предложить пройти курс соответствующих обследований в медицинском центре . Virathebot не только указывает возможные риски, но и подбирает персональную схему профилактики. Надежность данной электронной системы, подтверждено Всемирной Организации Здравоохранения, что является неоспоримым плюсом данного бота.
Персональный ассистент в Телеграмм «Запись к врачу», обладает уникальной системой идентификации заболевания, с жалобами на которое к нему обращается человек, тем самым помогая, определиться пользователю, к какому именно специалисту ему стоит обратиться в скором времени.
Бот поможет выбрать клинику, подобрать врача или же вызвать специалиста прямо к пациенту домой. Автоматизация данных процессов благодаря чату Telegram, в значительной мере экономит время. Такой индивидуальный подход к каждому клиенту, не может не радовать, он внушает доверие и чувство заботы.
Стоит ли сейчас делать себе бота?
Для пациентов престижных клиник , чат-боты в Telegram – это удобное и привлекательное предложение, в то время как для медицинских центров – это новая ступень в развитии, а также привлечение новой аудитории. С появлением инновационных технологий диагностики, записи на прием и онлайн консультации в Telegram, следить за своим здоровьем стало легко и приятно.
Источник: medispark.io
10 полезных телеграм-ботов, которые точно облегчат вашу жизнь
Заменят кучу приложений — от почты до переводчика, а также сэкономят время на поиске фильмов, картинок и книг.
Ни для кого не секрет, что телеграм-боты сейчас плотно наступают на пятки привычным сервисам, вытесняя их со смартфонов обычных пользователей. Сфера применения ботов довольно широка — от сервисов по работе с соцсетями до вполне бытовых помощников для решения обыденных задач. И всё это — не выходя из Телеграма.
Рекламное агентство NewDay поделилось телеграм-ботами, которые заменят вам кучу приложений — от почты до переводчика, а также сэкономят ваше время на поиске фильмов, картинок и книг.
Ещё больше полезной информации и интересных новостей вы сможете найти в Инстаграме агентства.
Источник: www.cossa.ru