A scorekeeping program for the board game Carcassonne

George C. Privon ff2e0c9d2e bugfix in manage_database.py. bump version 8 lat temu
analysis b43c91bea7 various analysis example updates 8 lat temu
.gitignore 0c5683c48b ignore swap files 8 lat temu
CHANGELOG.md ff2e0c9d2e bugfix in manage_database.py. bump version 8 lat temu
CarcassonneScore.py ff2e0c9d2e bugfix in manage_database.py. bump version 8 lat temu
LICENSE 7f294aa55a GPL3 license 8 lat temu
README.md 5db31e9b37 merge database routines into a single script 8 lat temu
cgame.py e40ca0fe14 define a global time format string. this should be abstracted to a config file so the analysis script can access it 8 lat temu
manage_database.py ff2e0c9d2e bugfix in manage_database.py. bump version 8 lat temu

README.md

Carcassonne Score keeping

Score keeping software for Carcassonne to facilitate statistical analysis of games.

Requirements

  • python 3 (tested under python 3.6.x)
  • numpy
  • matplotlib (for analysis scripts)

Usage

Before your first game you will need to initialize the sqlite database:

$ python manage_database.py --init

Score keeping

Assuming the database has been initialized, you can run a game with:

$ python CarcassonneScore.py

This launches the interactive shell. Press ? for a list of commands.

Database Maintenance

To update the database (add new players toggle availability of expansions), use the manage_database.py command. For example, to add a new player:

$ python manage_database.py -n NEW PLAYER

Use python manage_database.py -h to see the full list of options.

Analysis

A sample analysis jupyter notebook and a sample sqlite database containing one game is available in the analysis/ directory.