Pure Python 3 MTProto API Telegram client library, for bots too!
Go to file
Lonami Exo 3b1660669e Remove self input user and bot cache from client
The session_state cache can be used instead.
This does put get_me with input_peer at a disadvantage, but I expect
this is not used all that often, since 'me' does just fine.
2021-09-19 18:16:12 +02:00
.github Remove sync hack 2021-09-11 14:06:36 +02:00
readthedocs Update code to deal with the new sessions 2021-09-19 16:38:11 +02:00
telethon Remove self input user and bot cache from client 2021-09-19 18:16:12 +02:00
telethon_examples Address remaining uses of the Request suffix with raw API 2021-09-13 21:00:31 +02:00
telethon_generator Remove mark from peer_id 2021-09-18 16:29:45 +02:00
tests Fix imports 2021-09-12 13:27:13 +02:00
.coveragerc Add example unit test and config for testing 2019-12-07 04:23:27 +01:00
.gitignore Update and persist session state on successful login 2021-09-19 18:15:19 +02:00
.pre-commit-config.yaml Add pre-commit hooks configuration 2016-11-30 00:29:05 +03:00
dev-requirements.txt Add example unit test and config for testing 2019-12-07 04:23:27 +01:00
LICENSE Update proxy docs and license year 2021-02-12 17:56:46 +01:00
logo.svg Use better practices for logo's svg 2018-06-26 10:12:00 +02:00
optional-requirements.txt Replace PySocks with python-socks for Python >= 3.6 2020-11-09 19:59:54 +01:00
pyproject.toml Update documentation to include the new friendly method 2020-10-05 10:52:42 +02:00
README.rst Remove sync hack 2021-09-11 14:06:36 +02:00
requirements.txt Remove async_generator from dependencies 2019-02-27 11:13:29 +01:00
setup.py Adapt generator to new subpackage path 2021-09-12 12:35:48 +02:00
update-docs.sh Add set -e to update-docs.sh 2020-10-01 12:23:38 +02:00

Telethon
========
.. epigraph::

  ⭐️ Thanks **everyone** who has starred the project, it means a lot!

|logo| **Telethon** is an asyncio_ **Python 3**
MTProto_ library to interact with Telegram_'s API
as a user or through a bot account (bot API alternative).

.. important::

    If you have code using Telethon before its 1.0 version, you must
    read `Compatibility and Convenience`_ to learn how to migrate.

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.


Installing
----------

.. code-block:: sh

  pip3 install telethon


Creating a client
-----------------

.. code-block:: python

    import asyncio
    from telethon import TelegramClient, events

    # 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'

    async def main():
      client = TelegramClient('session_name', api_id, api_hash)
      await client.start()

    asyncio.run(main())


Doing stuff
-----------

.. code-block:: python

    print((await client.get_me()).stringify())

    await client.send_message('username', 'Hello! Talking to you from Telethon')
    await client.send_file('username', '/home/myself/Pictures/holidays.jpg')

    await client.download_profile_photo('me')
    messages = await client.get_messages('username')
    await messages[0].download_media()

    @client.on(events.NewMessage(pattern='(?i)hi|hello'))
    async def handler(event):
        await event.respond('Hey!')


Next steps
----------

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.

.. _asyncio: https://docs.python.org/3/library/asyncio.html
.. _MTProto: https://core.telegram.org/mtproto
.. _Telegram: https://telegram.org
.. _Compatibility and Convenience: https://docs.telethon.dev/en/latest/misc/compatibility-and-convenience.html
.. _Read The Docs: https://docs.telethon.dev

.. |logo| image:: logo.svg
    :width: 24pt
    :height: 24pt