带参数的电报Bot可点击命令

时间:2018-06-21 04:30:43

标签: python bots telegram telegram-bot

我正在使用python-telegram-bot创建一个Telegram机器人。

我试图在机器人消息中插入带有参数的命令,以便用户可以按它?

telegram core page上,我找到了一张图片,该图片描述了使用命令+参数(/ dl_)进行的聊天 enter image description here

但是我无法做到这一点

3 个答案:

答案 0 :(得分:2)

为您提供快速有效的解决方案:

#!/usr/bin/python3
from telegram.ext import Updater, MessageHandler, Filters
from telegram.ext import RegexHandler
from string import ascii_lowercase
from string import digits
from random import choice
from sys import exc_info as error

token = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'


def start(bot, update):
  username = update.message.from_user.first_name
  update.message.reply_text(greeting(username), parse_mode='Markdown')
  message = genre_head()

  for genre in genres:
    message += genre_list(genre['name'], genre['id'])

  update.message.reply_text(message, parse_mode='Markdown')

def artist(bot, update):
  genre_id = update.message.text.replace('/dl_', '')

  for genre in genres:
    if genre['id'] == genre_id:
       message = artist_head(genre['name'])

  for artist in artists:
    message += artist_list(artist['id'], artist['name'], genre_id)

  message += artist_list_end()
  update.message.reply_text(message, parse_mode='Markdown')

def download(bot, update):
  file = update.message.text.replace('/dl_', '')
  update.message.reply_text(u'\U0001F3BC\nhttp://music.com/{}.mp3'.format(file),
                            parse_mode='Markdown')

try:
  updater = Updater(token)
  dp = updater.dispatcher

  dp.add_handler(RegexHandler('/start', start))
  dp.add_handler(RegexHandler('^(/dl_[\d]+)$', artist))
  dp.add_handler(RegexHandler('^(/dl_[\d]+[\w]+)$', download))
  dp.add_handler(MessageHandler(Filters.text, start))

  updater.start_polling()
except:
  print(error())
  updater.stop()

################################################################################
# Messeges
def greeting(first_name):
  return '*Hello and welcome, {}!*\n'.format(first_name)

def genre_head():
  return '*What your favorite genre?*\n'

def genre_list(genre_name, genre_id):
  return '\n{}*{}*\n[ Choose {} /dl_{} ]\n'.format(u'\U0001F3B6', genre_name,
                                                   u'\U0001F449', genre_id)

def artist_head(genre_name):
  return 'What artist in {}*{}* you are looking for?\n'.format(u'\U0001F3B6',
                                                               genre_name)

def artist_list(artist_id, artist_name, genre_id):
  return '\n{} *{}*\n[Press for download {} /dl_{}{}]\n'.format(u'\U0001F468',
                                                                artist_name,
                                                                u'\U0001F449',
                                                                genre_id,
                                                                artist_id)

def artist_list_end():
  return '\n\nIf you choose a wrong genre press {} /start'.format(u'\U0001F449')

################################################################################
# Fake data
def digit():
  return ''.join(choice(digits) for iter in range(4))

def char():
  return ''.join(choice(ascii_lowercase) for iter in range(4))

genres = [{'id':digit(), 'name':'Rock'},
          {'id':digit(), 'name':'Classic'},
          {'id':digit(), 'name':'Pop'},
          {'id':digit(), 'name':'Dance'}]

artists = [{'id':char(), 'name':'Led Zeppeling'},
           {'id':char(), 'name':'Johann Sebastian Bach'},
           {'id':char(), 'name':'Madonna'},
           {'id':char(), 'name':'Tiesto'}]

答案 1 :(得分:1)

查看以下已解决的问题:https://github.com/python-telegram-bot/python-telegram-bot/issues/696

这个概念很简单:

  • 匹配以/dl_开头的邮件
  • 去除该部分并验证其余部分
  • 处理任何需要处理的东西

答案 2 :(得分:0)

您可以使用RegexHandler()进行此操作。

这是一个示例

def download(bot, update):
  id = update.message.text.replace('/dl_', '')
  update.message.reply_text(id, parse_mode='Markdown')


def main():
  updater = Updater(TOKEN)
  updater.dispatcher.add_handler(RegexHandler('^(/dl_[\d]+)$', download))
  updater.start_polling()

用法

命令/info_120将返回120
并且/info_007将返回007