Home

Awesome

chess_export

PyPi version Python 3.7|3.8|3.9|3.10 PRs Welcome

Export your (or someone else's) chess.com/lichess.org games using their APIs

Installation

Requires python3.8+

To install with pip, run:

pip install chess-export

Usage

Each subcommand (chessdotcom/lichess) has an export and inspect command -- export prints data about your games as JSON, inspect reads that dumped info so you can use it in the REPL.

The inspect command just accepts the file as the first argument, like chess_export lichess inspect data.json or chess_export chessdotcom inspect data.json

chessdotcom export

The only required argument is your username, the API serves public data and has no serial rate limit

$ chess_export chessdotcom export purarue >data.json
Requesting https://api.chess.com/pub/player/purarue/games/archives
Requesting https://api.chess.com/pub/player/purarue/games/2021/01
...

If you're getting 403 errors, you may have to supply a user agent with your email, see this forum thread

To do that, you can pass the --user-agent-email flag or set the CHESSDOTCOM_USER_AGENT_EMAIL environment variable.

lichess export

Requires your username and a token (this requires no extra scopes). The token can be provided with the --token flag or by setting the LICHESS_TOKEN environment variable.

$ chess_export lichess export purarue > data.json
Requesting https://lichess.org/api/games/user/purarue?pgnInJson=true

Example

The games are described in PGN (which can be parsed using the chess package)

$ chess_export chessdotcom export purarue >data.json
Requesting https://api.chess.com/pub/player/purarue/games/archives
Requesting https://api.chess.com/pub/player/purarue/games/2021/01
Requesting https://api.chess.com/pub/player/purarue/games/2021/02
$ chess_export chessdotcom inspect data.json

In [1]: import io, chess.pgn

In [2]: game = chess.pgn.read_game(io.StringIO(games[0].pgn))

In [3]: for move in game.mainline_moves():
   ...:     print(move)
   ...:
e2e4
e7e6
b1c3
d8f6
d2d3
f8c5
d3d4
c5d4
f2f3

The information returned by chess.com/lichess are slightly different, see the lichess/model.py and chessdotcom/model.py files for reference

Tests

git clone 'https://github.com/purarue/chess_export'
cd ./chess_export
pip install '.[testing]'
mypy ./chess_export