Poll¶
- class telegram.Poll(id, question, options, total_voter_count, is_closed, is_anonymous, type, allows_multiple_answers, correct_option_id=None, explanation=None, explanation_entities=None, open_period=None, close_date=None, question_entities=None, allows_revoting=None, members_only=None, correct_option_ids=None, description=None, description_entities=None, country_codes=None, media=None, explanation_media=None, *, api_kwargs=None)[source]¶
Bases:
telegram.TelegramObjectThis object contains information about a poll.
Objects of this class are comparable in terms of equality. Two objects of this class are considered equal, if their
idis equal.Examples
Available In
Returned In
- Parameters:
options (Sequence[
PollOption]) –List of poll options.
Changed in version 20.0: Accepts any
collections.abc.Sequenceas input instead of just a list. The input is converted to a tuple.is_anonymous (
bool) –True, if the poll is anonymous.allows_multiple_answers (
bool) –True, if the poll allows multiple answers.members_only (
bool) –True, if voting is limited to users who have been members of the chat where the poll was originally sent for more than24hours.Added in version 22.8.
correct_option_id (
int, optional) –A zero based identifier of the correct answer option. Available only for closed polls in the quiz mode, which were sent (not forwarded), by the bot or to a private chat with the bot.
Deprecated since version 22.8: Use
correct_option_idsinstead.explanation (
str, optional) – Text that is shown when a user chooses an incorrect answer or taps on the lamp icon in a quiz-style poll, 0-200characters.explanation_entities (Sequence[
telegram.MessageEntity], optional) –Special entities like usernames, URLs, bot commands, etc. that appear in the
explanation. This list is empty if the message does not contain explanation entities.Changed in version 20.0:
This attribute is now always a (possibly empty) list and never
None.Accepts any
collections.abc.Sequenceas input instead of just a list. The input is converted to a tuple.
explanation_media (
telegram.PollMedia, optional) –Media added to the quiz explanation.
Added in version 22.8.
open_period (
int|datetime.timedelta, optional) –Amount of time in seconds the poll will be active after creation.
Changed in version v22.2:
datetime.timedeltaobjects are accepted in addition to plainintvalues.close_date (
datetime.datetime, optional) –Point in time (Unix timestamp) when the poll will be automatically closed. Converted to
datetime.datetime.Changed in version 20.3: The default timezone of the bot is used for localization, which is UTC unless
telegram.ext.Defaults.tzinfois used.question_entities (Sequence[
telegram.MessageEntity], optional) –Special entities that appear in the
question. Currently, only custom emoji entities are allowed in poll questions.Added in version 21.2.
allows_revoting (
bool, optional) –True, if the poll allows to change the chosenanswer options.Added in version 22.8.
correct_option_ids (Sequence[
int], optional) –Array of 0-based identifiers of the correct answer options. Available only for polls in quiz mode which are closed or were sent (not forwarded) by the bot or to the private chat with the bot.
Added in version 22.8.
country_codes (Sequence[
str], optional) –A list of two-letter
ISO 3166-1 alpha-2country codes indicating the countries from which users can vote in the poll. The country code"FT"is used for users with anonymous numbers. If omitted, then users from any country can participate in the poll.Added in version 22.8.
description (
str, optional) –Description of the poll; for polls inside the
Messageobject only.Added in version 22.8.
description_entities (Sequence[
telegram.MessageEntity], optional) –Special entities like usernames, URLs, bot commands, etc. that appear in the description
Added in version 22.8.
media (
telegram.PollMedia, optional) –Media added to the poll description; for polls inside the
Messageobject only.Added in version 22.8.
- options[source]¶
List of poll options.
Changed in version 20.0: This attribute is now an immutable tuple.
- Type:
tuple[
PollOption]
- members_only[source]¶
True, if voting is limited to users who have been members of the chat where the poll was originally sent for more than24hours.Added in version 22.8.
- Type:
- explanation[source]¶
Optional. Text that is shown when a user chooses an incorrect answer or taps on the lamp icon in a quiz-style poll, 0-
200characters.- Type:
- explanation_entities[source]¶
Special entities like usernames, URLs, bot commands, etc. that appear in the
explanation. This list is empty if the message does not contain explanation entities.Changed in version 20.0: This attribute is now an immutable tuple.
Changed in version 20.0: This attribute is now always a (possibly empty) list and never
None.- Type:
tuple[
telegram.MessageEntity]
- explanation_media[source]¶
Optional. Media added to the quiz explanation.
Added in version 22.8.
- Type:
- open_period[source]¶
Optional. Amount of time in seconds the poll will be active after creation.
Deprecated since version v22.2: In a future major version this attribute will be of type
datetime.timedelta. You can opt-in early by setting PTB_TIMEDELTA=true orPTB_TIMEDELTA=1as an environment variable.- Type:
- close_date[source]¶
Optional. Point in time when the poll will be automatically closed.
Changed in version 20.3: The default timezone of the bot is used for localization, which is UTC unless
telegram.ext.Defaults.tzinfois used.- Type:
- question_entities[source]¶
Special entities that appear in the
question. Currently, only custom emoji entities are allowed in poll questions. This list is empty if the question does not contain entities.Added in version 21.2.
- Type:
tuple[
telegram.MessageEntity]
- allows_revoting[source]¶
True, if the poll allows to change the chosenanswer optionsAdded in version 22.8.
- Type:
- correct_option_ids[source]¶
Array of 0-based identifiers of the correct answer options. Available only for polls in quiz mode which are closed or were sent (not forwarded) by the bot or to the private chat with the bot.
Added in version 22.8.
- Type:
tuple[
int]
- country_codes[source]¶
Optional. A list of two-letter
ISO 3166-1 alpha-2country codes indicating the countries from which users can vote in the poll. The country code"FT"is used for users with anonymous numbers. If omitted, then users from any country can participate in the poll.Added in version 22.8.
- Type:
tuple[
str]
- description[source]¶
Optional. Description of the poll; for polls inside the Message object only
Added in version 22.8.
- Type:
- description_entities[source]¶
Special entities like usernames, URLs, bot commands, etc. that appear in the description
Added in version 22.8.
- Type:
tuple[
telegram.MessageEntity]
- media[source]¶
Optional. Media added to the poll description; for polls inside the Message object only.
Added in version 22.8.
- Type:
- MAX_DESCRIPTION_CHARACTERS = 1024[source]¶
telegram.constants.PollLimit.MAX_DESCRIPTION_CHARACTERSAdded in version 22.8.
- MAX_EXPLANATION_LENGTH = 200[source]¶
telegram.constants.PollLimit.MAX_EXPLANATION_LENGTHAdded in version 20.0.
- MAX_EXPLANATION_LINE_FEEDS = 2[source]¶
telegram.constants.PollLimit.MAX_EXPLANATION_LINE_FEEDSAdded in version 20.0.
- MAX_OPEN_PERIOD = 2628000[source]¶
telegram.constants.PollLimit.MAX_OPEN_PERIODAdded in version 20.0.
- MAX_OPTION_LENGTH = 100[source]¶
telegram.constants.PollLimit.MAX_OPTION_LENGTHAdded in version 20.0.
- MAX_OPTION_NUMBER = 12[source]¶
telegram.constants.PollLimit.MAX_OPTION_NUMBERAdded in version 20.0.
- MAX_QUESTION_LENGTH = 300[source]¶
telegram.constants.PollLimit.MAX_QUESTION_LENGTHAdded in version 20.0.
- MIN_MEMBERSHIP_HOURS = 24[source]¶
telegram.constants.PollLimit.MIN_MEMBERSHIP_HOURSAdded in version 22.8.
- MIN_OPEN_PERIOD = 5[source]¶
telegram.constants.PollLimit.MIN_OPEN_PERIODAdded in version 20.0.
- MIN_OPTION_LENGTH = 1[source]¶
telegram.constants.PollLimit.MIN_OPTION_LENGTHAdded in version 20.0.
- MIN_OPTION_NUMBER = 1[source]¶
telegram.constants.PollLimit.MIN_OPTION_NUMBERAdded in version 20.0.
- MIN_QUESTION_LENGTH = 1[source]¶
telegram.constants.PollLimit.MIN_QUESTION_LENGTHAdded in version 20.0.
- property correct_option_id[source]¶
A zero based identifier of the correct answer option. Available only for closed polls in the quiz mode, which were sent (not forwarded), by the bot or to a private chat with the bot.
Deprecated since version 22.8: Use
correct_option_idsinstead.
- parse_description_entities(types=None)[source]¶
Returns a
dictthat mapstelegram.MessageEntitytostr. It contains entities from this polls description filtered by theirtypeattribute as the key, and the text that each entity belongs to as the value of thedict.Added in version 22.8.
Note
This method should always be used instead of the
description_entitiesattribute, since it calculates the correct substring from the message text based on UTF-16 codepoints. Seeparse_description_entityfor more info.- Parameters:
types (list[
str], optional) – List ofMessageEntitytypes as strings. If thetypeattribute of an entity is contained in this list, it will be returned. Defaults totelegram.MessageEntity.ALL_TYPES.- Returns:
A dictionary of entities mapped to the text that belongs to them, calculated based on UTF-16 codepoints.
- Return type:
dict[
telegram.MessageEntity,str]- Raises:
RuntimeError – If the poll has no description.
- parse_description_entity(entity)[source]¶
Returns the text in
descriptionfrom a giventelegram.MessageEntityofdescription_entities.Added in version 22.8.
Note
This method is present because Telegram calculates the offset and length in UTF-16 codepoint pairs, which some versions of Python don’t handle automatically. (That is, you can’t just slice
Message.textwith the offset and length.)- Parameters:
entity (
telegram.MessageEntity) – The entity to extract the text from. It must be an entity that belongs todescription_entities.- Returns:
The text of the given entity.
- Return type:
- Raises:
RuntimeError – If the poll has no description.
- parse_explanation_entities(types=None)[source]¶
Returns a
dictthat mapstelegram.MessageEntitytostr. It contains entities from this polls explanation filtered by theirtypeattribute as the key, and the text that each entity belongs to as the value of thedict.Note
This method should always be used instead of the
explanation_entitiesattribute, since it calculates the correct substring from the message text based on UTF-16 codepoints. Seeparse_explanation_entityfor more info.- Parameters:
types (list[
str], optional) – List ofMessageEntitytypes as strings. If thetypeattribute of an entity is contained in this list, it will be returned. Defaults totelegram.MessageEntity.ALL_TYPES.- Returns:
A dictionary of entities mapped to the text that belongs to them, calculated based on UTF-16 codepoints.
- Return type:
dict[
telegram.MessageEntity,str]- Raises:
RuntimeError – If the poll has no explanation.
- parse_explanation_entity(entity)[source]¶
Returns the text in
explanationfrom a giventelegram.MessageEntityofexplanation_entities.Note
This method is present because Telegram calculates the offset and length in UTF-16 codepoint pairs, which some versions of Python don’t handle automatically. (That is, you can’t just slice
Message.textwith the offset and length.)- Parameters:
entity (
telegram.MessageEntity) – The entity to extract the text from. It must be an entity that belongs toexplanation_entities.- Returns:
The text of the given entity.
- Return type:
- Raises:
RuntimeError – If the poll has no explanation.
- parse_question_entities(types=None)[source]¶
Returns a
dictthat mapstelegram.MessageEntitytostr. It contains entities from this polls question filtered by theirtypeattribute as the key, and the text that each entity belongs to as the value of thedict.Added in version 21.2.
Note
This method should always be used instead of the
question_entitiesattribute, since it calculates the correct substring from the message text based on UTF-16 codepoints. Seeparse_question_entityfor more info.- Parameters:
types (list[
str], optional) – List ofMessageEntitytypes as strings. If thetypeattribute of an entity is contained in this list, it will be returned. Defaults totelegram.MessageEntity.ALL_TYPES.- Returns:
A dictionary of entities mapped to the text that belongs to them, calculated based on UTF-16 codepoints.
- Return type:
dict[
telegram.MessageEntity,str]
- parse_question_entity(entity)[source]¶
Returns the text in
questionfrom a giventelegram.MessageEntityofquestion_entities.Added in version 21.2.
Note
This method is present because Telegram calculates the offset and length in UTF-16 codepoint pairs, which some versions of Python don’t handle automatically. (That is, you can’t just slice
Message.textwith the offset and length.)- Parameters:
entity (
telegram.MessageEntity) – The entity to extract the text from. It must be an entity that belongs toquestion_entities.- Returns:
The text of the given entity.
- Return type: