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

Простой способ создать чат-бот в телеграм за полчаса


Чат-боты стали неотъемлемой частью нашей жизни: они помогают нам покупать билеты на поезд, отслеживать посылки, быстро получать ответы на вопросы и многое-многое другое. Но если обобщать, то чат-бот помогает бизнесу решить 2 вида задач:

  1. Выполнять функции консультанта (отвечать на различного рода вопросы и принимать запросы для дальнейшей работы)
  2. Выполнять функции информатора (высылать новости, акционные предложения, напоминать о себе, вести по воронке продаж и т.д.)

Основной бонус чат-бота в том, что он собирает аудиторию, с которой в будущем можно взаимодействовать и заниматься допродажами, например. И если в facebook официально запрещено делать акционные рассылки, то чат-бот в телеграм вы можете использовать абсолютно свободно не боясь бана. Поэтому предлагаю создание чат-бота именно в телеграм.

Прежде чем мы перейдем к созданию чат-бота я хотела бы сразу снизить ваши ожидания. Чат-бот хорош для выполнения рутинных задач, выявления потребностей, например. Но не стоит ожидать от него золотой жилы лидогенерации. Люди легко вовлекаются и отвечают на вопросы, а вот контакты свои оставляют не охотно, поэтому отнеситесь к чат-боту, как к дополнительному источнику коммуникации и сбора аудитории, которую позже придется доводить до покупки взаимодействием.

 

Какой ресурс использовать для создания чат-бота в телеграм?

В этой статье мы рассмотрим создание чат-бота в сервисе sendpulse.ua Основной функционал этого ресурса бесплатный, а интерфейс прост в использовании и интуитивно понятен. Но похожие чат-боты можно создать также на других ресурсах и даже с помощью самого телеграма. Поэтому все зависит только от ваших целей и технических навыков.

Создание бота в телеграме и регистрация

Первое, что необходимо сделать – это зарегистрировать чат-бот в телеграм и подключить его к Sendpulse. Очень подробная инструкция как это сделать есть вот в этой статье – https://sendpulse. ua/ru/knowledge-base/chatbot/create-telegram-chatbot

Обратите внимание, что @BotFather в котором вы создаете ваш чат-бот позволяет его не только создать, но и добавить описание, аватарку и многое другое. Ниже приведу несколько основных команд, которые вам пригодятся для создания чат-бота.

Команда /setabouttext позволяет добавить короткое описание вашего бота, чтобы человек понимал что это за чат-бот и для чего нужен

Команда /setuserpic позволяет добавить аватарку вашего бота

Команда /setname позволяет сменить название вашего бота
Команда /deletebot позволяет удалить ваш бот

 

Структура чат-бота

После того как вы уже создали свой бот, подключили к ресурсу sendpulse можно переходить к его наполнению и структуре. Рекомендую создавать структуру еще до того как вы начнете создавать бот. Для этого продумайте на какие вопросы бот будет отвечать и какие целевые действия от пользователей вы хотели бы получить.

Например, ваш бот будет помогать туристам выбирать отели для отдыха в Египте. Для этого составьте список вопросов на которые вы хотите получить ответы.

Это может выглядеть примерно вот так:

  • С кем вы планируете путешествие? (варианты ответов: с детьми, с друзьями, любимым человеком)
  • Важно ли для вас проживание на первой линии? (варианты ответов: да, нет, без разницы)
  • Какие отели вы рассматриваете? (варианты ответов: бюджетные, цена-качество, с высоким сервисом)
  • Важен ли для вас собственный риф при отеле? (варианты ответов: да, нет)

Когда у вас будет костяк вопросов подумайте о целевом действии, которое человек должен совершить. Например, в данном случае вы хотите не просто рекомендовать отели, а и получить контакты туриста. Для этого продумайте на каком этапе это должно происходить. Например, есть вариант не предлагать туристу варианты отелей, а просто после ответа на вопросы сразу просить оставить контакты. Таким образом вы уже выявляете потребности, но еще не даете конкретных предложений. Или же наоборот, после ответов на все вопросы человек получает варианты отелей, может сам выбрать какой из них ему подходит и в итоге оставить свои контакты, чтобы узнать стоимость.

 

Возможности чат-бота от Sendpulse

После того как вы зарегистрировали чат-бот, продумали его структуру и определились с целями – пришло время переходить к практической части, а именно созданию чат-бота. Все начинается с «приветственной серии» она запускается как только человек попадает в ваш бот и нажимает кнопку «запустить».

В «приветственной серии» важно рассказать о возможностях вашего бота и с чем он поможет пользователю, а также побудить к действию идти дальше. Для этого вы можете как написать ему следующее сообщение, так и сразу предложить какой-то выбор и основываясь на его выборе вести его дальше. Вот пример того как может выглядеть структура вашего бота.

Если ваш чат-бот будет выявлять потребности, то не стоит задавать слишком много вопросов 3-5 основных будет достаточно. А вот в финале оставляйте один из элементов не решенным. Например, не давайте варианты отелей, предложите оставить контакты, чтобы получить подборку отелей. Многих это злит, но людям необходима завершенность, поэтому шанс, что контакты все же оставят очень велика.

Дополнительные функции

RSS канал
Кроме основного функционала составления сообщений чат-бота, sendpulse позволяет настроить автоматический постинг в чат-бот через RSS канал. Например, на вашем сайте есть активный блог или акционные предложения, которые постоянно меняются. Вам достаточно настроить RSS канал и они автоматически будут публиковаться в чат-бот.
Оплата услуг в чат-боте
Ваши услуги можно оплатить прямо в чат-боте. Подойдет, например, для каких-то мероприятий или небольших предоплат.
Вебхуки
Если для вас важна интеграция, то Sendpulse позволяет подключить свое API и отправлять вебхуки. Все это доступно в платном тарифе.



Как создать бота в Telegram? (всего 4 пункта)




Опубликовано в:
Чат-боты

Прочитано:21


 
Чат-боты (1)

1. В поиске по контактам Telegram (левый верхний угол) необходимо ввести “botfather” — название бота, который создает ботов. Вы можете также найти этого бота по нашей ссылке.

2. Напишите боту команду “/newbot” — с помощью нее он создаст для вас нового бота.

3. Затем, напишите имя бота

4. Напишите ник бота. Он должен быть уникальным, а также в конце названия должно быть слово “bot”. Например, “testbot77777_bot”. Если название будет не уникальным, то бот напишет, что имя уже занято (см. наш пример ниже).

5. Ура! Вы создали бота! Далее необходимо скопировать токен (ключ) API из приветственного сообщения, которое нам отправит botfather:

6. На следующем шаге нам необходимо перейти в конструктор Чат-ботов MCN Telecom. Нажмите на иконку Telegram в верхнем правом углу и во всплывающем окне добавьте скопированный токен. После чего созданный сценарий автоматически подгрузится в вашего бота.

Теперь в нашем конструкторе доступна функция Deep Linking — это гиперссылка, которая перенаправляет пользователя в конкретный раздел приложения или сайта. Эта функция сокращает количество промежуточных действий пользователя и помогает ему попасть на нужную страницу за минимальное количество кликов. В нашем случае эта функция ведет на нужный элемент в чат-боте.

У каждого бота есть ссылка, открывающая с ним беседу в Telegram — https://t.me/. К этой ссылке можно добавить параметры start или startgroup со значениями длиной до 64 символов. Например:

https://t.me/triviabot?startgroup=test

Переход по ссылке с параметром запуска откроет личный диалог с ботом, показывая кнопку СТАРТ вместо поля ввода.

Далее мы разберем пример того, как подключить «Глубокую ссылку» и эффективно ее использовать.

  1. После того, как мы подключили бота в личном кабинете, создадим небольшой сценарий.
  2. Добавим элемент «сравнение» на страницу нашего чат-бота. В качестве первого операнда возьмем переменную ${{telegram_start}}, а второй будет равен 1.
  3. У нас есть 2 варианта значений. Если переменная будет «Истина», то сценарий пойдет по первой ветке. Если же «Ложь», то мы создаем еще один элемент «Сравнение», присваивая первому операнду ${{telegram_start}}, а второму 2.
  4. Вторым шагом нужно правильно составить ссылку, которая ведет на вашего бота:
  5. https://t.me/?start=

    Важно!!! A-Z, a-z, 0-9, _И — разрешены. Мы рекомендуем использовать base64url для кодирования параметров с двоичными и другими типами содержимого.

    Таким образом, у нас будут 2 ссылки на нашего бота с параметром «1» и параметром «2». Каждая ссылка будет вести на определенную ветку в сценарии.

2.5.14.17. Telegram Bot — документация по Buildbot 2.9.1

Caution

Buildbot больше не поддерживает Python 2.7 на мастере Buildbot.

Buildbot предлагает бота, аналогичного IRC , для мобильного и настольного приложения для обмена сообщениями Telegram. Бот может уведомлять пользователей и группы о событиях сборки, отвечать на запросы о состоянии или форсировать и останавливать сборки по запросу (если это разрешено).

Чтобы использовать этого репортера, вы должны сначала поговорить с BotFather и создать нового бота телеграммы. Быстрая пошаговая процедура выглядит следующим образом:

  1. Начать чат с BotFather.

  2. Тип /newbot .

  3. Введите отображаемое имя для вашего бота. Это может быть любая строка.

  4. Введите уникальное имя пользователя для вашего бота. Имена пользователей имеют длину от 5 до 32 символов и нечувствительны к регистру, но могут включать только латинские буквы, цифры и символы подчеркивания. Имя пользователя вашего бота должно заканчиваться на bot , например. MyBuildBot или MyBuildbotBot .

  5. Вам будет подарен токен для вашего бота. Сохраните его, так как он понадобится вам для настройки TelegramBot .

  6. При желании вы можете ввести /setcommands , выбрать имя пользователя вашего нового бота и вставить следующий текст:

     команд - список доступных команд
    force - принудительно построить
    getid - получить идентификатор пользователя и чата
    привет - поздоровайся
    help - дать справку по команде или одному из ее аргументов
    last - список последних статусов сборки для строителя
    list - список настроенных сборщиков или рабочих
    нет - забыть текущую команду
    notify - уведомлять меня о событиях сборки
    shutdown - выключить мастер билдбота
    source - исходный код для buildbot
    status - список статусов билдера (или всех билдеров)
    stop - остановить работающую сборку
    version - показать версию билдбота
    watch - объявить о завершении активной сборки
     

    Если вы сделаете это, Telegram предоставит подсказки о ваших командах бота.

  7. При желании вы можете установить собственное изображение и описание для своего бота.

После настройки бота в Telegram необходимо настроить его в Buildbot.

 из репортеров импорта buildbot.plugins
телеграмма = репортеры.TelegramBot(
        bot_token='bot_token_given_by_botfather',
        bot_username'username_set_in_botfather_bot',
        chat_ids=[-1234567],
        authz={('force', 'stop'): "авторизованный ник"}
        уведомление_события=[
            'исключение',
            'проблема',
            'восстановление',
            'рабочий'
        ],
        usePolling=Истина)
c['услуги'].append(телеграмма)
 

Этот класс принимает следующие параметры:

bot_token

(обязательный)
Токен бота, предоставленный BotFather.

bot_username

(необязательно)
Это должно быть установлено на уникальное имя пользователя бота, определенное в BotFather. Если этот параметр отсутствует, он будет получен с сервера Telegram. Однако в случае проблем с подключением настройка Buildbot будет прервана. По этой причине рекомендуется установить для этого параметра правильное значение.

chat_ids

(необязательно)
Список идентификаторов чатов для отправки уведомлений, указанных в параметре notify_events . Для каналов он должен иметь форму @channelusername , а для приватных чатов и групп это должен быть числовой идентификатор. Чтобы получить его, поговорите со своим ботом или добавьте его в группу Telegram и введите команду /getid .

Примечание

Чтобы получить уведомление от бота, вам нужно сначала поговорить с ним (и нажать 9кнопка 0007 /start ) или добавьте его в групповой чат.

авторизация

(дополнительно)
Список аутентификации для команд. Это должен быть словарь с именами команд (без косой черты) или кортежами имен команд в качестве ключей. Есть два специальных имени команд: '' (пустая строка), означающая любую безвредную команду, и '!' для опасных команд (в настоящее время /force , /stop и /shutdown ). Значения словаря равны True из False (что разрешает или запрещает выполнение команд для всех) или список числовых идентификаторов, уполномоченных выполнять определенные команды. По умолчанию безобидные команды разрешены для всех, а опасные запрещены.

Пример параметра authz может выглядеть следующим образом:

 авториз =(
  'getid': Правда,
  '': [123456, 789012],
  («принудительно», «стоп»): [123456],
)
 

Любой сможет запустить команду getid , пользователи с идентификаторами 123456 и 789012 будет разрешено запускать любую безопасную команду, а пользователь с идентификатором 123456 также будет иметь право принудительно запускать и останавливать сборки.

теги

(опционально)
Если установлено, этот бот будет сообщать только о сборщиках, содержащих эти теги.
(функция тегов еще не реализована)

notify_events

(необязательно)
Список или набор событий, о которых нужно сообщать в чатах Telegram.
Бот Telegram может прослушивать события «начало» и «завершение» сборки. Он также может оповещать об отсутствующих работниках и их возвращении.
Этот параметр можно изменить во время выполнения, отправив команду 9Команда 0007 /notify боту. Однако обратите внимание, что при перезапуске или перенастройке билдбота перечисленные здесь уведомления будут включены для указанных чатов. С другой стороны, удаление событий из этого параметра не приведет к автоматической остановке уведомлений для них (нужно отключить их для каждого канала командой /notify ).

showBlameList

(необязательно, по умолчанию отключено)
Отображать ли список виновных для неудачных сборок.
(функция списка обвинений еще не реализована)

useRevisions

(необязательно, по умолчанию отключено)
Отображать ли ревизию, ведущую к сборке, о которой сообщается в сообщениях.
(функциональность useRevisions еще не реализована)

useWebhook

(необязательно, по умолчанию отключено)
По умолчанию этот бот получает сообщения от Telegram через опрос. Вы можете настроить его на использование веб-хука, что может быть более эффективным. Однако для этого требуется, чтобы веб-интерфейс Buildbot был настроен и доступен через HTTPS (не HTTP) на общедоступном IP-адресе и номере порта 443, 80, 88 или 8443. Кроме того, параметр конфигурации Buildbot buildbotURL должен быть правильно установлен. Если вы используете HTTP-аутентификацию, убедитесь, что адрес buildbotURL /telegram bot_token (например, https://buildbot.example.com/telegram123456:secret ) доступен всем.

сертификат

(опционально)
Содержимое SSL-сертификата вашего сервера. Это необходимо, если доступ к веб-интерфейсу Buildbot осуществляется по протоколу HTTPS с самоподписанным сертификатом и userWebhook имеет значение True .

pollTimeout

(опционально)
Время, которое бот должен ждать, пока Telegram ответит на опрос с помощью длинного опроса.

повторная задержка

(опционально)
Задержка, которую бот должен ожидать перед попыткой повторной попытки связи в случае отсутствия соединения.

Чтобы воспользоваться услугой, вы отправили боту Telegram-команды (сообщения, начинающиеся со слэша). В большинстве случаев вам не нужно добавлять какие-либо параметры; бот спросит вас о деталях.

Некоторые из доступных в настоящее время команд:

/getid

Получить идентификатор пользователя и группы. Это полезно для поиска числовых идентификаторов, которые следует указать в параметрах конфигурации authz и chat_ids .

/list

Выдать список всех настроенных сборщиков, рабочих или последних изменений.

/status

Оглашаем статус всех строителей.

/watch

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

/last

Возвращает результаты последних сборок для каждого компоновщика.

/notify

Отчет о событиях, связанных со сборками.
Если команда выдается как личное сообщение, то отчет будет отправлен обратно как личное сообщение пользователю, выпустившему команду.
В противном случае отчет будет отправлен в групповой чат.
Доступные события для уведомления:

запущено

Сборка запущена.

завершено

Сборка завершена.

успех

Сборка завершена успешно.

сбой

Ошибка сборки.

исключение

Создана сборка и исключение.

отменен

Сборка отменена.

проблема

Результатом предыдущей сборки был успех или предупреждения, но эта завершилась ошибкой или исключением.

восстановление

Это противоположно проблеме : результатом предыдущей сборки был сбой или исключение, а эта завершилась успехом или предупреждениями.

хуже

Состояние сборки было хуже, чем предыдущее (например, оно закончилось предупреждениями, а предыдущее было успешным).

лучше

Состояние сборки было лучше, чем предыдущее.

рабочий

Пропал рабочий. Уведомление также отправляется, когда ранее заявленный пропавший работник снова подключается.

По умолчанию эту команду может выполнить кто угодно. Однако подумайте об ограничении его с помощью authz , так как включение уведомлений в огромном количестве чатов (любого типа) может вызвать некоторые проблемы с эффективностью вашего билдбота.

/help

Показать краткую справку по командам.

/commands

Список всех доступных команд.
Если вы явно наберете /commands botfather , бот ответит списком команд с краткими описаниями, которые должны быть предоставлены BotFather.

/source

Объявите URL-адрес домашней страницы Buildbot.

/версия

Сообщите версию этого Buildbot.

Если явно разрешено в конфигурации authz , будут доступны некоторые дополнительные команды: Бот прочитает конфигурацию из каждого настроенного ForceScheduler и предоставит вам параметры сборки, которые вы можете изменить. Если вы установите все необходимые параметры, вам будет предоставлена ​​возможность начать сборку.

/stop

Остановить сборку. Если есть какие-либо активные сборки, вам будут предложены варианты их остановки.

/shutdown

Управление процессом завершения работы мастера Buildbot.
Вам будет предложено начать плавное завершение работы, остановить его или немедленно завершить работу.

Если вы находитесь в процессе разговора с ботом (например, он только что задал вам вопрос), вы всегда можете остановить текущую команду командой /нет .

Если установлен тег (см. параметр тегов в конфигурации билдера), изменения, относящиеся только к билдерам, принадлежащим этим тегам билдеров, будут отправлены в канал.

Если для параметра useRevisions установлено значение True , бот IRC будет отправлять сообщения о состоянии, в которых номер сборки заменяется списком ревизий, содержащихся в этой сборке.
Таким образом, вместо сборки № 253 из … вы увидите что-то вроде 9.Сборка 0029, содержащая ревизии a87b2c4 .
Ревизии, которые хранятся в виде хэшей, укорачиваются до 7 символов, так как в одной сборке может содержаться несколько ревизий, что может привести к слишком длинным сообщениям.

Как создать и развернуть бота Telegram с помощью Flask

Поделиться

Ответить

  • 0

Damilare Jolayemi Подписаться
Дамиларе с энтузиазмом решает проблемы, ей нравится создавать все, что работает на компьютере. У него есть умение хлопать по клавиатуре, пока что-то не сработает. Когда он не разговаривает со своим ноутбуком, вы можете увидеть, как он путешествует и делится моментами со своими друзьями или смотрит сериалы на Netflix.


6 минут чтения
1806 г.

Сегодня почти каждый веб-сайт или приложение SaaS использует чат-бота. Чат-боты предоставляют согласованную информацию, круглосуточное обслуживание и быстрое время отклика. Было показано, что эти инструменты снижают затраты бизнеса и повышают удовлетворенность клиентов.

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

  • Широковещательное сообщение
  • Напоминания
  • Индивидуальные уведомления и новости
  • Обучение пользователей
  • Игры
  • Приложения для поисковых систем
  • Интеграция с другими сервисами

В этой статье мы расскажем, как настроить бота Telegram, а затем интегрировать его с Flask, чтобы быстро создать настраиваемое приложение-словарь и развернуть его на Heroku.

Настройка профиля бота Telegram

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

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

Чтобы настроить бота Telegram, начните с входа в свой профиль Telegram. Если вы еще не создали профиль в Telegram, вы можете зарегистрироваться здесь.

Затем найдите BotFather, вставив @BotFather в строку поиска Telegram. BotFather — это бот-администратор Telegram, который позволяет пользователям создавать и управлять ботами.

После запуска BotFather нажмите кнопку START или введите команду /start в поле ввода пользовательского интерфейса, чтобы начать разговор.

BotFather ответит на /start со списком других команд, которые можно вызывать для выполнения различных операций:

Чтобы создать нового бота, введите команду /newbot в поле ввода. BotFather ответит, спросив подробности о новом боте:

Далее вы получите сообщение от BotFather, содержащее токен HTTP. Не раскрывайте этот токен. Любой, у кого есть доступ к токену, сможет вносить изменения в вашего бота.

Мы будем использовать этот токен для взаимодействия с новым ботом через Telegram API из нашего приложения Flask.

Создание приложения Flask

Flask — это веб-фреймворк Python с открытым исходным кодом. Его легкая кодовая база делает его пригодным для быстрого создания веб-приложений.

В этом примере мы создадим приложение Flask, которое будет функционировать как словарь. Наше приложение получит английское слово в качестве запроса и ответит информацией о слове, такой как его определение(я), пример, синонимы и антонимы. Для этого приложения мы будем использовать бесплатный словарь API.

Во-первых, создайте папку Flask_Telegram , чтобы содержать приложение и cd в каталоге.

 mkdir Flask_Telegram
компакт-диск Flask_Telegram 

Установить запрашивает библиотеку для отправки HTTP-запросов к внешнему API каталога:

 запросов на установку пипсов 

Затем создайте файл Dictionary.py , который будет содержать логику предоставления информации о запрошенном слове. Затем добавьте следующий фрагмент кода:

.

 импорт ОС
запросы на импорт
из фляги импорт фляги
приложение = фляга (__имя__)
@app.route('/')
определение get_info (слово):
    url = 'https://api.dictionaryapi.dev/api/v2/entries/en/{}'.format(word)
    ответ = запросы.get(url)
# вернуть пользовательский ответ, если указано недопустимое слово
    если response.status_code == 404:
        error_response = 'Мы не можем предоставить никакой информации о вашем слове. Пожалуйста, подтвердите, что это слово ' \
                         'написано правильно или повторите поиск позже.'
        вернуть error_response
    данные = ответ.json () [0]
    печать (данные)
    возвращаемые данные
get_info("еда")
если __name__ == "__main__":
    порт = int(os. environ.get('ПОРТ', 5000))
    app.run(debug=True, хост='0.0.0.0', порт=порт) 

В приведенном выше примере файлdiction.py , @app.route('/') — это точка входа в приложение.

Когда пользователь запрашивает информацию о слове , это значение передается в функцию get_info() . Затем мы добавляем функцию к переменной url перед отправкой запроса в API словаря.

Прежде чем выполнять какие-либо дополнительные операции, мы сначала проверяем, является ли запрос допустимым английским словом. Успешный запрос к API словаря возвращает данные JSON в виде списка. Затем мы извлекаем данные JSON из списка и возвращаем их клиенту. Однако в случае запроса недопустимого слова возвращается статус кода 404, и пользователю отображается пользовательское сообщение.


Более 200 000 разработчиков используют LogRocket для улучшения цифрового взаимодействия

Подробнее →


Вот ожидаемый ответ, когда приложение получает запрос информации о продуктах питания :

Интеграция приложения Flask с ботом Telegram

Давайте доработаем приложение, интегрировав наш скрипт словаря Flask с нашим ботом Telegram.

Сначала создайте новый файл Python, bot.py и добавьте следующий фрагмент кода:

 импортная телеграмма
из telegram.ext импортировать Updater, MessageHandler, Filters
из telegram.ext импортировать CommandHandler
импорт из словаря get_info
telegram_bot_token =
updater = Updater (токен = telegram_bot_token, use_context = True)
диспетчер = updater.dispatcher
# настроить вводную фразу для бота при вызове команды /start
def start (обновление, контекст):
    чат_ид = обновление.эффективный_чат.идентификатор
    context.bot.send_message(chat_id=chat_id, text="Привет. Укажите любое английское слово, и я дам вам кучу "
                                                   «информации об этом».)
# получить информацию о предоставленном слове и формате перед представлением.
def get_word_info (обновление, контекст):
    # получить информацию о слове
    word_info = get_info(обновление.сообщение.текст)
    # Если пользователь вводит недопустимое английское слово, возвращаем пользовательский ответ от get_info() и выходим из функции
    если word_info. __class__ является str:
        update.message.reply_text(word_info)
        возвращаться
    # получить слово, предоставленное пользователем
    слово = слово_информация['слово']
    # получить происхождение слова
    происхождение = слово_информация ['происхождение']
    значения = '\n'
    синонимы = ''
    определение = ''
    пример = ''
    антонимы = ''
    # слово может иметь несколько значений. Мы будем использовать этот счетчик для отслеживания каждого из значений, предоставленных в ответе.
    значение_счетчик = 1
    для word_meaning в word_info['значения']:
        значения += 'Значение' + str(meaning_counter) + ':\n'
        для word_definition в word_meaning['definitions']:
            # извлечь каждое из определений слова
            определение = слово_определение['определение']
            # извлечь каждый пример для соответствующего определения
            если «пример» в word_definition:
                пример = слово_определение['пример']
            # извлечь коллекцию синонимов для слова на основе определения
            для word_synonym в word_definition['synonyms']:
                синонимы += word_synonym + ', '
            # извлечь антонимы слова на основе определения
            для word_antonym в word_definition['antonyms']:
                антонимы += слово_антоним + ', '
        значения += 'Определение: ' + определение + '\n\n'
        значения += 'Пример: ' + пример + '\n\n'
        значения += 'Синоним: ' + синонимы + '\n\n'
        значения += 'Антоним: ' + антонимы + '\n\n\n'
        значение_счетчик += 1
    # форматируем данные в строку
    message = f"Слово: {слово}\n\nПроисхождение: {происхождение}\n{значения}"
    update. message.reply_text(сообщение)
# запустить функцию запуска, когда пользователь вызывает команду /start
диспетчер.add_handler (обработчик команд («старт», старт))
# вызывать функцию get_word_info, когда пользователь отправляет сообщение
# это не команда.
диспетчер.add_handler (MessageHandler (Фильтры.текст, get_word_info))
updater.start_polling() 

В этом примере мы сначала импортируем модули Telegram и скрипт словаря в файл bot.py . Затем мы инициализируем средство обновления Telegram с помощью нашего уникального токена HTTP.

Функция start(update, context) содержит логику для отображения пользовательского приветственного сообщения при выполнении команды бота /start . Мы инициируем разговор с пользователем через функцию context.bot.send_message , используя chat_id , чтобы определить, куда направить ответ.

В функции get_word_info мы выполняем логику для форматирования данных, полученных из функции get_info в сценарии Dictionary. py .

Если пользователь вводит допустимое английское слово, функция get_info возвращает тип данных словаря: dict . С этим типом данных мы выполняем дальнейшие операции, извлекая данные, которые хотим отобразить пользователю. Извлеченные значения затем форматируются в строку и сохраняются в сообщение переменная.

Однако, если пользователь вводит недопустимое английское слово, функция get_info вернет строковый тип данных: str . Когда это происходит, пользователю показывается пользовательское сообщение, созданное в файле Dictionary.py .

В качестве последнего шага мы говорим боту Telegram выполнять функцию start, когда пользователь вызывает команду /start , и выполнять функцию get_word_info , когда пользователь отправляет сообщение, не являющееся командой.

Развертывание бота Telegram

Давайте развернем наше приложение на удаленном сервере. Мы будем использовать облачную платформу Heroku для размещения нашего приложения.

Если у вас еще нет учетной записи в Heroku, вы можете создать ее здесь.

Чтобы развернуть бота Telegram, выполните следующие шесть шагов:

1. Создайте

файл requirements.txt

Файл requirements.txt содержит зависимости и соответствующие версии, необходимые приложению для успешной работы.

Выполните следующую команду, чтобы сгенерировать файл requirements.txt , содержащий зависимости, которые использовались для создания бота Telegram:

 замораживание пипсов > требования.txt 

Файл requirements.txt должен содержать как минимум следующие пакеты:

 питон-телеграмма-бот == 13.8.1
телеграмма==0.0.1
запросы == 2.25.1 

В зависимости от типа приложения файл requirements.txt может содержать больше пакетов и, возможно, другие номера версий.

2. Создайте

Procfile

Procfile — это текстовый файл, определяющий команду, которая должна выполняться на Heroku при запуске приложения.

Для этого примера создайте файл в корневом каталоге приложения и назовите его Procfile . Затем добавьте следующий фрагмент кода:

.

 веб: python bot.py $ПОРТ 

3. Создайте приложение Heroku

Используйте следующую команду, чтобы указать Heroku создать приложение с указанным именем:

 героку создать 

После успешного выполнения этой команды Heroku предоставит два URL-адреса: URL-адрес приложения и URL-адрес удаленного Git, через который Heroku развернет приложение на своем сервере.

4. Добавьте пакет сборки приложения

Чтобы просмотреть приложение, перейдите на панель управления Heroku. На вкладке Settings щелкните Add buildpack и выберите параметр heroku/python :

5. Измените

bot.py файл

Перед развертыванием бота на Heroku нам нужно внести небольшие изменения в часть updater.start_polling() файла bot. py .

Этот шаг необходим, поскольку метод updater.start_polling() отслеживает API Telegram на наличие новых сообщений. Поскольку мы будем запускать бота на удаленном веб-сервере, нам нужно указать Telegram напрямую связываться с веб-сервером.

Заменить updater.start_polling() со следующим фрагментом кода:

 updater.start_webhook(listen="0.0.0.0",
                      порт = int (os.environ.get ('ПОРТ', 5000)),
                      url_path=telegram_bot_token,
                      webhook_url= + telegram_bot_token
                      ) 

6. Разверните приложение

Используйте следующие команды для развертывания приложения Telegram на Heroku:

 git добавить .
git commit -m "первая фиксация"
git push героку основной 

Вывод

В этой статье мы продемонстрировали, как быстро создать приложение-словарь, интегрировав бота Telegram и Flask. Этот проект доступен на GitHub, и вы можете взаимодействовать с ботом словаря, который мы создали здесь.