Python关于使用Telethon在Telegram中获取最新消息的使用方法@client.on(events.NewMessage(chats=[-10011111111])) || @client.on(events.NewMessage(chats=[PeerChannel(123456789)]))

不应将“标记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的“原始”对象,而这些是原始的真实值。

留下评论

您的电子邮箱地址不会被公开。 必填项已用 * 标注

+ 38 = 47