不应将“标记ID”和“对等”实例的概念混合在一起。您可以使用:
@client.on(events.NewMessage(chats=[PeerChannel(123456789)])) async def my_event_handler(event): print(event.raw_text) client.start() client.run_until_disconnected()
或者
@client.on(events.NewMessage(chats=[-100123456789])) async def my_event_handler(event): print(event.raw_text) client.start() client.run_until_disconnected()
上面的 event.raw_text 就表示消息文字
两者不可同时使用
下面是关于里面ID号的解释
The ` -100 ` prefix tells Telethon it’s a ` Channel ` (megagroups, also known as supergroups, are also ` Channel ` ).
The ` – ` prefix tells Telethon it’s a ` Chat ` .
The ` + ` prefix tells Telethon it’s a ` User ` .
这遵循与Telegram HTTP Bot API相同的约定。
如果不使用前缀,Telethon将在高速缓存中查找所有类型。如果不在缓存中,它将尝试使用User。
如果使用前缀,Telethon将仅从缓存中获取该类型。如果不在缓存中,它将尝试使用您的前缀说的类型。
在内部
-100123 == PeerChannel(123) -123 == PeerChat(123) 123 == PeerUser(123)
event.chat_id,event.user_id和client.get_peer_id都返回带前缀的ID,因为它对库很有帮助,并且对用户方便。
更新是Telegram的“原始”对象,而这些是原始的真实值。