Python wrapper for the Lichess API
Project description
lichess: a Python wrapper for the Lichess API
lichess is a Python library for interacting with the Lichess API and can be used to get profile data, game data, and much more.
This project is still in Pre-Alpha. As a result, it is still unstable, and not all features have been implemented.
Installation
You can install lichess on the Terminal (macOS/UNIX) or the Command Prompt (Windows) with:
pip install lichess
Alternatively, you can use Git to clone the repository from GitHub with:
git clone https://github.com/qe/lichess.git cd lichess pip install .
Or, if you already have it, upgrade to the latest version with:
pip install lichess -U
Usage
For the full documentation, please check the Lichess Python API Documentation.
Some methods, such as Client.get_email(), require authorization while others, such as Client.get_leaderboard(), do not require it. As a result, if you want to use a method/endpoint that does require authorization, you will need to generate a personal access token on Lichess. If you do so, this will be your API Key.
To determine whether or nor you need to generate a personal access token, check if the endpoint you are interested in using has a OAuth2 badge in the Lichess API Documentation.
Here is an example of using lichess without a personal access token:
import lichess myclient = lichess.Client()
Here is an example of using lichess with a personal access token:
import lichess API_KEY = "<YOUR API KEY GOES HERE>" myclient = lichess.Client(token=API_KEY)
Quick Examples
The following are some examples of popular uses of this package:
Get the profile data of a user
myclient = lichess.Client() user = myclient.get_data("bmartin")
Get the list of users that are offline, online, and playing
myclient = lichess.Client() users = ["Oliver_Penrose", "bmartin", "ismodes", "penguingim1", "Zhigalko_Sergei"] data = myclient.get_status(users) offline = [i['name'] for i in data if 'online' not in i.keys()] online = [i['name'] for i in data if 'online' in i.keys()] playing = [i['name'] for i in data if 'playing' in i.keys()]
Download all the games of a user
myclient = lichess.Client() games = myclient.export_by_user(<USERNAME GOES HERE>) with open("games.pgn", "w") as f: f.write(games) f.close()
Get the list of all the members of a team
API_KEY = "<YOUR API KEY GOES HERE>" myclient = lichess.Client(token=API_KEY) members = myclient.get_team_members(<TEAMNAME GOES HERE>)
Get the list of all the IDs of the puzzles you have failed
API_KEY = "<YOUR API KEY GOES HERE>" myclient = lichess.Client(token=API_KEY) activity = myclient.get_puzzle_activity() failed = [i['id'] for i in activity if not i['win']]
For more examples, check the examples directory in the source code.
Endpoints
At the moment, here are the available methods for some of the Lichess API endpoints. Below, the methods with the ✓ symbol are working.
-- Account -------------------------------------------------------------- Get your public profile information ✓ get_profile() Get your email address ✓ get_email() Get your preferences ✓ get_preferences() Get your kid mode status ✓ get_kid_mode() Set your kid mode status ✗ set_kid_mode() -- Users ---------------------------------------------------------------- Get real-time status of one or more users ✓ get_status() Get the top 10 players for each speed and variant ✗ get_top_ten() Get leaderboard of an individual speed or variant ✗ get_leaderboard() Get public data of an individual user ✓ get_data() Get rating history of an individual user ✓ get_rating_history() Get performance statistics of an individual user ✓ get_stats() Get the activity feed of an individual user ✓ get_activity() Get users by ID ✗ get_by_id() Get the current live streamers ✓ get_live_streamers() Get the crosstable of two users ✓ get_crosstable() -- Relations ------------------------------------------------------------ Get users who you are following ✓ following() Follow a player ✗ follow() Unfollow a player ✗ unfollow() -- Games ---------------------------------------------------------------- Download a game by ID as PGN or JSON ✓ export_by_id() Download the ongoing game of a user in either JSON or PGN format ✓ export_ongoing_by_user() Download all games of a user as PGN or NDJSON ✓ export_by_user() Download games by IDs as PGN or NDJSON ✗ export_by_ids() Stream the games played between users ✗ stream_among_users() Get your ongoing games ✓ get_ongoing() Stream the moves/positions of any ongoing game ✗ stream_moves() Upload a PGN game ✗ import_by_pgn() -- TV ------------------------------------------------------------------- Get the best games currently being played for each speed/variant ✓ get_games_channels() Stream positions and moves of the current TV game ✗ stream_tv_game() Get the best games currently being played for a specific speed/variant ~ get_games_channel() -- Puzzles -------------------------------------------------------------- Get the daily puzzle as JSON ✓ get_daily_puzzle() Get your puzzle activity as NDJSON ✓ get_puzzle_activity() Get your puzzle dashboard as JSON ✓ get_puzzle_dashboard() Get the storm dashboard of any player as JSON ✓ get_storm_dashboard() -- Teams ---------------------------------------------------------------- Get all swiss tournaments of a team ✓ get_team_swiss() Get info about a team ✓ get_team_info() Get popular teams ✓ get_popular_teams() Get all the teams a player is a member of ✓ get_teams_player() Get search results for keyword in team search ✓ search_teams() Get members of a team ✓ get_team_members() . . . Get join requests ✗ get_join_requests() . . . -- Board ---------------------------------------------------------------- -- Bot ------------------------------------------------------------------ -- Challenges ----------------------------------------------------------- -- Bulk pairings -------------------------------------------------------- -- Arena tournaments ---------------------------------------------------- Get recently finished, ongoing, and upcoming tournaments ✓ get_arena_all() . . . Get info about an Arena tournament ✓ get_arena_info() . . . -- Swiss Tournaments ---------------------------------------------------- . . . Get info about a Swiss tournament ✓ get_swiss_info() . . . -- Simuls --------------------------------------------------------------- Get recently finished, ongoing, and upcoming simuls ✓ get_simuls() -- Studies -------------------------------------------------------------- -- Messaging ------------------------------------------------------------ -- Broadcasts ----------------------------------------------------------- -- Analysis ------------------------------------------------------------- -- Opening Explorer ----------------------------------------------------- -- Tablebase ------------------------------------------------------------ -- OAuth ----------------------------------------------------------------
Links
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file lichess-0.2.0.tar.gz
.
File metadata
- Download URL: lichess-0.2.0.tar.gz
- Upload date:
- Size: 13.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9c2444232a8493c5c1623348a4cea894a6cf5a2969fb8e550438179ccdc72897 |
|
MD5 | 1f96419d1a20f400fdf116f3e0a99a6e |
|
BLAKE2b-256 | a5361917b9cfb9382da687dc31ea1261b0ffba26834195e17f7470bce1005ba3 |
File details
Details for the file lichess-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: lichess-0.2.0-py3-none-any.whl
- Upload date:
- Size: 11.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88e4679f60829b8a009d45f7d4d601505eca7966427c01b23e134d02ec3df2be |
|
MD5 | 78c22495546aca277517ff835adb7168 |
|
BLAKE2b-256 | 7b6216a484debb174b3546b7fe6f62f086b99ca189c727dfd7acb7717ab8221e |