-
Notifications
You must be signed in to change notification settings - Fork 0
Type Checking
Since Python 3.6, static type hinting is established in Python and PTB makes use of it (since v13.0). Static type checking helps to avoid and find errors both in PTBs source code and in your bot code. If you want to take advantage of this, you should use a type checker to check your code. As type checking in general is not PTB specific and a big topic, we can't explain everything about it in this wiki. There are however some things that are specific to PTBs type checking and that advanced users might want to keep in mind. More precisely, some classes in telegram.ext
are Generics
. Below we detail, how to specify the corresponding types to get proper type checking.
While static type hints are of great value and we try our best to make them as precise as possible, they usually don't have any implications on runtime behavior. It therefore may happen that some type hints are not perfect or outright wrong and we may change & fix them between minor versions without announcement. This may lead to your type checker reporting errors after an upgrade, but it won't introduce bugs into your code.
Please also note that type hinting in Python does not cover all edge cases, so there might be situations where PTB just can't do better.
Of course, you are always welcome to report any type hinting erros through the bug tracker.
class MyHandler(Handler[UpdateClass, CallbackContextClass]):
...
Here UpdateClass
should the type of the updates that this handler will handle. In most cases, this will just be telegram.Update
. However, the handler setup is designed to be able to also handle other objects (e.g., to integrate 3rd party updates into your bot), so this could also be GitHubUpdateClass
or some other thing.
CallbackContextClass
is tha type of the context
argument. In most cases, this will just be CallbackContext
, but in case you're using a custom type for the context
argument (see also below), you should pass that instead.
class CustomContext(CallbackContext[UserDataClass, ChatDataClass, BotDataClass]):
...
The default type for all three is dict
, which you can use if you don't specify user/chat/bot_data
for your ContextTypes
instance.
class CustomPersistence(BasePersistence[UserDataClass, ChatDataClass, BotDataClass]):
...
Pretty much the same as for CallbackContext
Depending on whether you use a custom CallbackContext
class or not, you have two options here:
class CustomUpdaterOrDispatcher(Updater/Dispatcher[CallbackContext[UserDataClass, ChatDataClass, BotDataClass], UserDataClass, ChatDataClass, BotDataClass]):
...
or
class CustomUpdaterOrDispatcher(Updater/Dispatcher[CustomContext, UserDataClass, ChatDataClass, BotDataClass]):
...
- Wiki of
python-telegram-bot
© Copyright 2015-2025 – Licensed by Creative Commons
- Architecture Overview
- Builder Pattern for
Application
- Types of Handlers
- Working with Files and Media
- Exceptions, Warnings and Logging
- Concurrency in PTB
- Advanced Filters
- Storing data
- Making your bot persistent
- Adding Defaults
- Job Queue
- Arbitrary
callback_data
- Avoiding flood limits
- Webhooks
- Bot API Forward Compatiblity
- Frequently requested design patterns
- Code snippets
- Performance Optimizations
- Telegram Passport
- Bots built with PTB
- Automated Bot Tests