MessageEntity¶
- class telegram.MessageEntity(type, offset, length, url=None, user=None, language=None, custom_emoji_id=None, *, api_kwargs=None)[source]¶
Bases:
telegram.TelegramObjectThis object represents one special entity in a text message. For example, hashtags, usernames, URLs, etc.
Objects of this class are comparable in terms of equality. Two objects of this class are considered equal, if their
type,offsetandlengthare equal.Use In
Available In
- Parameters:
Type of the entity. Can be
MENTION(@username),HASHTAG(#hashtagor#hashtag@chatusername),CASHTAG($USDorUSD@chatusername),BOT_COMMAND(/start@jobs_bot),URL(https://telegram.org),EMAIL(do-not-reply@telegram.org),PHONE_NUMBER(+1-212-555-0123),BOLD(bold text),ITALIC(italic text),UNDERLINE(underlined text),STRIKETHROUGH,SPOILER(spoiler message),BLOCKQUOTE(block quotation),CODE(monowidth string),PRE(monowidth block),TEXT_LINK(for clickable text URLs),TEXT_MENTION(for users without usernames),CUSTOM_EMOJI(for inline custom emoji stickers).Added in version 20.0: Added inline custom emoji
Added in version 20.8: Added block quotation
offset (
int) – Offset in UTF-16 code units to the start of the entity.url (
str, optional) – ForTEXT_LINKonly, url that will be opened after user taps on the text.user (
telegram.User, optional) – ForTEXT_MENTIONonly, the mentioned user.language (
str, optional) – ForPREonly, the programming language of the entity text.custom_emoji_id (
str, optional) –For
CUSTOM_EMOJIonly, unique identifier of the custom emoji. Usetelegram.Bot.get_custom_emoji_stickers()to get full information about the sticker.Added in version 20.0.
- type[source]¶
Type of the entity. Can be
MENTION(@username),HASHTAG(#hashtagor#hashtag@chatusername),CASHTAG($USDorUSD@chatusername),BOT_COMMAND(/start@jobs_bot),URL(https://telegram.org),EMAIL(do-not-reply@telegram.org),PHONE_NUMBER(+1-212-555-0123),BOLD(bold text),ITALIC(italic text),UNDERLINE(underlined text),STRIKETHROUGH,SPOILER(spoiler message),BLOCKQUOTE(block quotation),CODE(monowidth string),PRE(monowidth block),TEXT_LINK(for clickable text URLs),TEXT_MENTION(for users without usernames),CUSTOM_EMOJI(for inline custom emoji stickers).Added in version 20.0: Added inline custom emoji
Added in version 20.8: Added block quotation
- Type:
- url[source]¶
Optional. For
TEXT_LINKonly, url that will be opened after user taps on the text.- Type:
- user[source]¶
Optional. For
TEXT_MENTIONonly, the mentioned user.- Type:
- custom_emoji_id[source]¶
Optional. For
CUSTOM_EMOJIonly, unique identifier of the custom emoji. Usetelegram.Bot.get_custom_emoji_stickers()to get full information about the sticker.Added in version 20.0.
- Type:
- ALL_TYPES = [<MessageEntityType.BLOCKQUOTE>, <MessageEntityType.BOLD>, <MessageEntityType.BOT_COMMAND>, <MessageEntityType.CASHTAG>, <MessageEntityType.CODE>, <MessageEntityType.CUSTOM_EMOJI>, <MessageEntityType.EMAIL>, <MessageEntityType.EXPANDABLE_BLOCKQUOTE>, <MessageEntityType.HASHTAG>, <MessageEntityType.ITALIC>, <MessageEntityType.MENTION>, <MessageEntityType.PHONE_NUMBER>, <MessageEntityType.PRE>, <MessageEntityType.SPOILER>, <MessageEntityType.STRIKETHROUGH>, <MessageEntityType.TEXT_LINK>, <MessageEntityType.TEXT_MENTION>, <MessageEntityType.UNDERLINE>, <MessageEntityType.URL>][source]¶
A list of all available message entity types.
- Type:
list[
str]
- BLOCKQUOTE = 'blockquote'[source]¶
telegram.constants.MessageEntityType.BLOCKQUOTEAdded in version 20.8.
- CUSTOM_EMOJI = 'custom_emoji'[source]¶
telegram.constants.MessageEntityType.CUSTOM_EMOJIAdded in version 20.0.
- EXPANDABLE_BLOCKQUOTE = 'expandable_blockquote'[source]¶
telegram.constants.MessageEntityType.EXPANDABLE_BLOCKQUOTEAdded in version 21.3.
- SPOILER = 'spoiler'[source]¶
telegram.constants.MessageEntityType.SPOILERAdded in version 13.10.
- static adjust_message_entities_to_utf_16(text, entities)[source]¶
Utility functionality for converting the offset and length of entities from Unicode (
str) to UTF-16 (utf-16-leencodedbytes).Tip
Only the offsets and lengths calulated in UTF-16 is acceptable by the Telegram Bot API. If they are calculated using the Unicode string (
strobject), errors may occur when the text contains characters that are not in the Basic Multilingual Plane (BMP). For more information, see Unicode and Plane (Unicode).Added in version 21.4.
Examples
Below is a snippet of code that demonstrates how to use this function to convert entities from Unicode to UTF-16 space. The
unicode_entitiesare calculated in Unicode and the utf_16_entities are calculated in UTF-16.text = "𠌕 bold 𝄢 italic underlined: 𝛙𝌢𑁍" unicode_entities = [ MessageEntity(offset=2, length=4, type=MessageEntity.BOLD), MessageEntity(offset=9, length=6, type=MessageEntity.ITALIC), MessageEntity(offset=28, length=3, type=MessageEntity.UNDERLINE), ] utf_16_entities = MessageEntity.adjust_message_entities_to_utf_16( text, unicode_entities ) await bot.send_message( chat_id=123, text=text, entities=utf_16_entities, ) # utf_16_entities[0]: offset=3, length=4 # utf_16_entities[1]: offset=11, length=6 # utf_16_entities[2]: offset=30, length=6
- Parameters:
entities (Sequence[
telegram.MessageEntity]) – Sequence of entities with offset and length calculated in Unicode
- Returns:
Sequence of entities with offset and length calculated in UTF-16 encoding
- Return type:
Sequence[
telegram.MessageEntity]
- classmethod concatenate(*args)[source]¶
Utility functionality for concatenating two text along with their formatting entities.
Tip
This function is useful for prefixing an already formatted text with a new text and its formatting entities. In particular, it automatically correctly handles UTF-16 encoding.
Examples
This example shows a callback function that can be used to add a prefix and suffix to the message in a
CallbackQueryHandler:async def prefix_message(update: Update, context: ContextTypes.DEFAULT_TYPE): prefix = "𠌕 bold 𝄢 italic underlined: 𝛙𝌢𑁍 | " prefix_entities = [ MessageEntity(offset=2, length=4, type=MessageEntity.BOLD), MessageEntity(offset=9, length=6, type=MessageEntity.ITALIC), MessageEntity(offset=28, length=3, type=MessageEntity.UNDERLINE), ] suffix = " | 𠌕 bold 𝄢 italic underlined: 𝛙𝌢𑁍" suffix_entities = [ MessageEntity(offset=5, length=4, type=MessageEntity.BOLD), MessageEntity(offset=12, length=6, type=MessageEntity.ITALIC), MessageEntity(offset=31, length=3, type=MessageEntity.UNDERLINE), ] message = update.effective_message first = (prefix, prefix_entities, True) second = (message.text, message.entities) third = (suffix, suffix_entities, True) new_text, new_entities = MessageEntity.concatenate(first, second, third) await update.callback_query.edit_message_text( text=new_text, entities=new_entities, )
Hint
The entities are not modified in place. The function returns a new sequence of objects.
Added in version 21.5.
- Parameters:
*args (tuple[
str, Sequence[telegram.MessageEntity]] | tuple[str, Sequence[telegram.MessageEntity],bool]) – Arbitrary number of tuples containing the text and its entities to concatenate. If the last element of the tuple is abool, it is used to determine whether to adjust the entities to UTF-16 viaadjust_message_entities_to_utf_16(). UTF-16 adjustment is disabled by default.- Returns:
The concatenated text and its entities
- Return type:
tuple[
str, Sequence[telegram.MessageEntity]]
- static shift_entities(by, entities)[source]¶
Utility functionality for shifting the offset of entities by a given amount.
Examples
Shifting by an integer amount:
text = "Hello, world!" entities = [ MessageEntity(offset=0, length=5, type=MessageEntity.BOLD), MessageEntity(offset=7, length=5, type=MessageEntity.ITALIC), ] shifted_entities = MessageEntity.shift_entities(1, entities) await bot.send_message( chat_id=123, text="!" + text, entities=shifted_entities, )
Shifting using a string:
text = "Hello, world!" prefix = "𝄢" entities = [ MessageEntity(offset=0, length=5, type=MessageEntity.BOLD), MessageEntity(offset=7, length=5, type=MessageEntity.ITALIC), ] shifted_entities = MessageEntity.shift_entities(prefix, entities) await bot.send_message( chat_id=123, text=prefix + text, entities=shifted_entities, )
Tip
The
entitiesare not modified in place. The function returns a sequence of new objects.Added in version 21.5.
- Parameters:
by (
str|int) – Either the amount to shift the offset by or a string whose length will be used as the amount to shift the offset by. In this case, UTF-16 encoding will be used to calculate the length.entities (Sequence[
telegram.MessageEntity]) – Sequence of entities
- Returns:
Sequence of entities with the offset shifted
- Return type:
Sequence[
telegram.MessageEntity]