telegram.ext.PrefixHandler#

class telegram.ext.PrefixHandler(prefix, command, callback, filters=None, block=True)[source]#

Bases: telegram.ext.CommandHandler

Handler class to handle custom prefix commands.

This is an intermediate handler between MessageHandler and CommandHandler. It supports configurable commands with the same options as CommandHandler. It will respond to every combination of prefix and command. It will add a list to the CallbackContext named CallbackContext.args. It will contain a list of strings, which is the text following the command split on single or consecutive whitespace characters.

Examples

Single prefix and command:

PrefixHandler("!", "test", callback)  # will respond to '!test'.

Multiple prefixes, single command:

PrefixHandler(["!", "#"], "test", callback)  # will respond to '!test' and '#test'.

Multiple prefixes and commands:

PrefixHandler(
    ["!", "#"], ["test", "help"], callback
)  # will respond to '!test', '#test', '!help' and '#help'.

By default, the handler listens to messages as well as edited messages. To change this behavior use ~filters.UpdateType.EDITED_MESSAGE

Note

Warning

When setting block to False, you cannot rely on adding custom attributes to telegram.ext.CallbackContext. See its docs for more info.

Parameters
callback[source]#

The callback function for this handler.

Type

coroutine function

filters[source]#

Optional. Only allow updates with these Filters.

Type

telegram.ext.filters.BaseFilter

block[source]#

Determines whether the return value of the callback should be awaited before processing the next handler in telegram.ext.Application.process_update().

Type

bool

check_update(update)[source]#

Determines whether an update should be passed to this handler’s callback.

Parameters

update (telegram.Update | object) – Incoming update.

Returns

The list of args for the handler.

Return type

list

property command[source]#

The list of commands this handler should listen for.

Returns

List[str]

property prefix[source]#

The prefixes that will precede command.

Returns

List[str]