2017-08-24 20:08:21 +03:00
|
|
|
Telethon
|
|
|
|
========
|
|
|
|
.. epigraph::
|
|
|
|
|
|
|
|
⭐️ Thanks **everyone** who has starred the project, it means a lot!
|
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
|logo| **Telethon** is an asyncio_ **Python 3**
|
2019-01-05 19:31:26 +03:00
|
|
|
MTProto_ library to interact with Telegram_'s API
|
|
|
|
as a user or through a bot account (bot API alternative).
|
2018-06-21 22:54:54 +03:00
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
.. important::
|
|
|
|
|
|
|
|
If you have code using Telethon before its 1.0 version, you must
|
|
|
|
read `Compatibility and Convenience`_ to learn how to migrate.
|
2018-01-09 20:04:51 +03:00
|
|
|
|
|
|
|
What is this?
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Telegram is a popular messaging application. This library is meant
|
|
|
|
to make it easy for you to write Python programs that can interact
|
|
|
|
with Telegram. Think of it as a wrapper that has already done the
|
|
|
|
heavy job for you, so you can focus on developing an application.
|
|
|
|
|
|
|
|
|
2017-08-24 20:08:21 +03:00
|
|
|
Installing
|
|
|
|
----------
|
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
.. code-block:: sh
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-27 14:05:19 +03:00
|
|
|
pip3 install telethon
|
2017-08-24 20:08:21 +03:00
|
|
|
|
|
|
|
|
|
|
|
Creating a client
|
|
|
|
-----------------
|
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
.. code-block:: python
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
from telethon import TelegramClient, events, sync
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-21 22:54:54 +03:00
|
|
|
# These example values won't work. You must get your own api_id and
|
|
|
|
# api_hash from https://my.telegram.org, under API Development.
|
|
|
|
api_id = 12345
|
|
|
|
api_hash = '0123456789abcdef0123456789abcdef'
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-21 22:54:54 +03:00
|
|
|
client = TelegramClient('session_name', api_id, api_hash)
|
2018-06-25 22:14:58 +03:00
|
|
|
client.start()
|
2017-08-24 20:08:21 +03:00
|
|
|
|
|
|
|
|
|
|
|
Doing stuff
|
|
|
|
-----------
|
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
.. code-block:: python
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-25 22:14:58 +03:00
|
|
|
print(client.get_me().stringify())
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-25 22:14:58 +03:00
|
|
|
client.send_message('username', 'Hello! Talking to you from Telethon')
|
|
|
|
client.send_file('username', '/home/myself/Pictures/holidays.jpg')
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-06-25 22:14:58 +03:00
|
|
|
client.download_profile_photo('me')
|
|
|
|
messages = client.get_messages('username')
|
|
|
|
messages[0].download_media()
|
2017-08-24 20:08:21 +03:00
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
@client.on(events.NewMessage(pattern='(?i)hi|hello'))
|
|
|
|
async def handler(event):
|
|
|
|
await event.respond('Hey!')
|
|
|
|
|
2017-08-24 20:08:21 +03:00
|
|
|
|
|
|
|
Next steps
|
|
|
|
----------
|
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
Do you like how Telethon looks? Check out `Read The Docs`_ for a more
|
|
|
|
in-depth explanation, with examples, troubleshooting issues, and more
|
|
|
|
useful information.
|
2018-06-24 16:51:24 +03:00
|
|
|
|
2018-10-06 21:20:11 +03:00
|
|
|
.. _asyncio: https://docs.python.org/3/library/asyncio.html
|
|
|
|
.. _MTProto: https://core.telegram.org/mtproto
|
|
|
|
.. _Telegram: https://telegram.org
|
2019-05-09 15:09:22 +03:00
|
|
|
.. _Compatibility and Convenience: https://telethon.readthedocs.io/en/latest/misc/compatibility-and-convenience.html
|
2018-10-06 21:20:11 +03:00
|
|
|
.. _Read The Docs: https://telethon.readthedocs.io
|
2018-06-24 16:51:24 +03:00
|
|
|
|
|
|
|
.. |logo| image:: logo.svg
|
|
|
|
:width: 24pt
|
|
|
|
:height: 24pt
|