You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
17 KiB
17 KiB
In [1]:
import logging from telegram import ReplyKeyboardMarkup, Update from telegram.ext import ( Updater, CommandHandler, MessageHandler, Filters, ConversationHandler, PicklePersistence, CallbackContext, ) # Enable logging logging.basicConfig( format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO ) logger = logging.getLogger(__name__) CHOOSING, TYPING_REPLY, TYPING_CHOICE = range(3) reply_keyboard = [ ['Submit Translation!'], ['Want an Explaination?', 'Go to the Project'], ['Done'], ] markup = ReplyKeyboardMarkup(reply_keyboard, one_time_keyboard=True) def facts_to_str(user_data): facts = list() for key, value in user_data.items(): facts.append('{} - {}'.format(key, value)) return "\n".join(facts).join(['\n', '\n']) def start(update: Update, context: CallbackContext) -> None: reply_text = "Hi! My name is Doctor Botter." if context.user_data: reply_text += ( " You already told me your {}. Why don't you tell me something more " "about yourself? Or change anything I " "already know.".format(", ".join(context.user_data.keys())) ) else: reply_text += ( " I will hold a more complex conversation with you. Why don't you tell me " "something about yourself?" ) update.message.reply_text(reply_text, reply_markup=markup) return CHOOSING def regular_choice(update: Update, context: CallbackContext) -> None: text = update.message.text.lower() context.user_data['choice'] = text if context.user_data.get(text): reply_text = 'Your {}, I already know the following ' 'about that: {}'.format( text, context.user_data[text] ) else: reply_text = 'Your {}? Yes, I would love to hear about that!'.format(text) update.message.reply_text(reply_text) return TYPING_REPLY def explaination(update: Update, context: CallbackContext) -> None: update_obj.message.reply_text(f"This is an explaination", reply_markup= markup) def project(update: Update, context: CallbackContext) -> None: update_obj.message.reply_text(f"Here it is! \n \n https://issue.xpub.nl/", reply_markup= markup) def received_information(update: Update, context: CallbackContext) -> None: text = update.message.text category = context.user_data['choice'] context.user_data[category] = text.lower() del context.user_data['choice'] update.message.reply_text( "Neat! Just so you know, this is what you already told me:" "{}" "You can tell me more, or change your opinion on " "something.".format(facts_to_str(context.user_data)), reply_markup=markup, ) return CHOOSING def show_data(update: Update, context: CallbackContext) -> None: update.message.reply_text( "This is what you already told me:" "{}".format(facts_to_str(context.user_data)) ) def done(update: Update, context: CallbackContext) -> None: if 'choice' in context.user_data: del context.user_data['choice'] update.message.reply_text( "I learned these facts about you:" "{}" "Until next time!".format(facts_to_str(context.user_data)) ) return ConversationHandler.END def main(): # Create the Updater and pass it your bot's token. pp = PicklePersistence(filename='conversationbot') updater = Updater("1452534708:AAERTrbN_LUDSLkf0J8sJjvMEEuwfRNka50", persistence=pp, use_context=True) # Get the dispatcher to register handlers dp = updater.dispatcher # Add conversation handler with the states CHOOSING, TYPING_CHOICE and TYPING_REPLY conv_handler = ConversationHandler( entry_points=[CommandHandler('/start', start)], states={ CHOOSING: [ MessageHandler( Filters.regex('^Explaination?$'), explaination ), MessageHandler(Filters.regex('^Project$'), project ), MessageHandler(Filters.regex('^Translation!$'), regular_choice, ) ], TYPING_CHOICE: [ MessageHandler( Filters.text & ~(Filters.command | Filters.regex('^Done$')), start ) ], TYPING_REPLY: [ MessageHandler( Filters.text & ~(Filters.command | Filters.regex('^Done$')), received_information, ) ], }, fallbacks=[MessageHandler(Filters.regex('^Done$'), done)], name="my_conversation", persistent=True, ) dp.add_handler(conv_handler) show_data_handler = CommandHandler('show_data', show_data) dp.add_handler(show_data_handler) # Start the Bot updater.start_polling() # Run the bot until you press Ctrl-C or the process receives SIGINT, # SIGTERM or SIGABRT. This should be used most of the time, since # start_polling() is non-blocking and will stop the bot gracefully. updater.idle() #if __name__ == '__main__': main()
--------------------------------------------------------------------------- UnboundLocalError Traceback (most recent call last) <ipython-input-1-78e99e9459bb> in <module> 167 168 if __name__ == '__main__': --> 169 main() <ipython-input-1-78e99e9459bb> in main() 120 dp = updater.dispatcher 121 --> 122 dp.add_handler(conv_handler) 123 124 show_data_handler = CommandHandler('show_data', show_data) UnboundLocalError: local variable 'conv_handler' referenced before assignment
In [ ]:
#!/usr/bin/env python # -*- coding: utf-8 -*- # pylint: disable=W0613, C0116, C0103 # type: ignore[union-attr] # This program is dedicated to the public domain under the CC0 license. """ First, a few callback functions are defined. Then, those functions are passed to the Dispatcher and registered at their respective places. Then, the bot is started and runs until we press Ctrl-C on the command line. Usage: Example of a bot-user conversation using ConversationHandler. Send /start to initiate the conversation. Press Ctrl-C on the command line or send a signal to the process to stop the bot. """ import logging from telegram import ReplyKeyboardMarkup, Update from telegram.ext import ( Updater, CommandHandler, MessageHandler, Filters, ConversationHandler, PicklePersistence, CallbackContext, ) # Enable logging logging.basicConfig( format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO ) logger = logging.getLogger(__name__) CHOOSING, TYPING_REPLY, TYPING_CHOICE = range(3) reply_keyboard = [ ['Age', 'Favourite colour'], ['Number of siblings', 'Something else...'], ['Done'], ] markup = ReplyKeyboardMarkup(reply_keyboard, one_time_keyboard=True) def facts_to_str(user_data): facts = list() for key, value in user_data.items(): facts.append('{} - {}'.format(key, value)) return "\n".join(facts).join(['\n', '\n']) def start(update: Update, context: CallbackContext) -> None: reply_text = "Hi! My name is Doctor Botter." if context.user_data: reply_text += ( " You already told me your {}. Why don't you tell me something more " "about yourself? Or change anything I " "already know.".format(", ".join(context.user_data.keys())) ) else: reply_text += ( " I will hold a more complex conversation with you. Why don't you tell me " "something about yourself?" ) update.message.reply_text(reply_text, reply_markup=markup) return CHOOSING def regular_choice(update: Update, context: CallbackContext) -> None: text = update.message.text.lower() context.user_data['choice'] = text if context.user_data.get(text): reply_text = 'Your {}, I already know the following ' 'about that: {}'.format( text, context.user_data[text] ) else: reply_text = 'Your {}? Yes, I would love to hear about that!'.format(text) update.message.reply_text(reply_text) return TYPING_REPLY def custom_choice(update: Update, context: CallbackContext) -> None: update.message.reply_text( 'Alright, please send me the category first, ' 'for example "Most impressive skill"' ) return TYPING_CHOICE def received_information(update: Update, context: CallbackContext) -> None: text = update.message.text category = context.user_data['choice'] context.user_data[category] = text.lower() del context.user_data['choice'] update.message.reply_text( "Neat! Just so you know, this is what you already told me:" "{}" "You can tell me more, or change your opinion on " "something.".format(facts_to_str(context.user_data)), reply_markup=markup, ) return CHOOSING def show_data(update: Update, context: CallbackContext) -> None: update.message.reply_text( "This is what you already told me:" "{}".format(facts_to_str(context.user_data)) ) def done(update: Update, context: CallbackContext) -> None: if 'choice' in context.user_data: del context.user_data['choice'] update.message.reply_text( "I learned these facts about you:" "{}" "Until next time!".format(facts_to_str(context.user_data)) ) return ConversationHandler.END def main(): # Create the Updater and pass it your bot's token. pp = PicklePersistence(filename='conversationbot') updater = Updater("1452534708:AAERTrbN_LUDSLkf0J8sJjvMEEuwfRNka50", persistence=pp, use_context=True) # Get the dispatcher to register handlers dp = updater.dispatcher # Add conversation handler with the states CHOOSING, TYPING_CHOICE and TYPING_REPLY conv_handler = ConversationHandler( entry_points=[CommandHandler('start', start)], states={ CHOOSING: [ MessageHandler( Filters.regex('^(Age|Favourite colour|Number of siblings)$'), regular_choice ), MessageHandler(Filters.regex('^Something else...$'), custom_choice), ], TYPING_CHOICE: [ MessageHandler( Filters.text & ~(Filters.command | Filters.regex('^Done$')), regular_choice ) ], TYPING_REPLY: [ MessageHandler( Filters.text & ~(Filters.command | Filters.regex('^Done$')), received_information, ) ], }, fallbacks=[MessageHandler(Filters.regex('^Done$'), done)], name="my_conversation", persistent=True, ) dp.add_handler(conv_handler) show_data_handler = CommandHandler('show_data', show_data) dp.add_handler(show_data_handler) # Start the Bot updater.start_polling() # Run the bot until you press Ctrl-C or the process receives SIGINT, # SIGTERM or SIGABRT. This should be used most of the time, since # start_polling() is non-blocking and will stop the bot gracefully. updater.idle() if __name__ == '__main__': main()
2020-11-16 13:23:06,337 - apscheduler.scheduler - INFO - Scheduler started
In [ ]:
In [ ]:
In [ ]:
In [ ]:
In [ ]: