Skip to main content

A command-line tool for Kattis

Project description

Kattis-CLI

Kattis CLI - download, test and submit Kattis problems using CLI or TUI. Inspired by the official Kattis CLI: https://github.com/Kattis/kattis-cli

Tests PyPI version PyPI - Downloads PyPI - License

Quick Tour of Kattis-CLI

Kattis-CLI

Requirements

  • Python 3.8+ (PyPy preferred as Kattis uses PyPy to run your Python3 solutions)
  • Kattis account

Windows

  • Use Command Line or PowerShell
  • Make sure python is in your PATH
    • Install Python from Windows Store
  • if you get codec error while running kattis-cli, run the following command in Command Prompt:
python --version
chcp 65001

Installation

If you've Python version 3.8 or higher, you can skip creating virtual environment. If you wish to create a virtual environment, see intructions below.

Create and activate virtual environment using venv

Create and activate virtual environment using conda

Install Kattis-cli

  • activate virtual environment if you've created one for kattis-cli
  • run the following command in Command Prompt or PowerShell
pip install kattis-cli
python -m pip install kattis-cli
kattis --version
  • on Windows add the path shown in the output of the above command to your PATH environment variable

Update/Upgrade Kattis-CLI

  • remove or rename .kattis-cli.toml file in your home directory
  • activate virtual environment if you've created one for kattis-cli
kattis --version
pip install kattis-cli --upgrade
python -m pip install kattis-cli --upgrade
  • on Windows add the path shown in the output of the above command to your PATH environment variable

Kattis configuration

  • run the following command and enter your Kattis credentials
  • follow the instructions provided in the terminal
kattis setup

Manual Configuration

  • see SETUP.md for detailed instructions to setup kattis-cli

Usage

kattis <command> [options]
kattis --help
kattis tui # get into text user interface mode

Commands

Download a problem sample files and it's metadata

Problem id

kattis get <problem_id>

Get problem id from URL

Display problem metadata

cd <problem_id>
kattis info

Problem info

Creating project template

  • create project template files for a given programming language
  • src style default templates are created in the home directory under .kattis-templates folder
  • you can overwrite/create new templates following the structure provided kattis_templates
  • local languages codes supported are:
    • python3
    • c++
    • java
    • c
    • nodejs
kattis template --help
# create python3 project template for cold problem
kattis template -l python3 -p cold -s

Test a solution locally

Test

  • currently the following languages have been tested: Python 3, C++, NodeJS, C, Java
  • make sure CLI compilers are in your PATH
  • make sure python3 files have first line shebang: !/usr/bin/env python3
    • or have extensions .py3
  • update the .kattis-cli.toml file in your home directory to add more languages
  • see kattis_cli/.kattis-cli.toml file for example.
cd <problem_id>
kattis test # for exact comparion of answers (string and int)
kattis test -a 6 # Answer accepted upto 6 decimal places of accuracy

Testing floating point results

  • for floating point ouput, problem provides the tolerance or accuracy upto certain decimal points
  • one can use -a <N> switch after kattis test command to provide the decimal places of accuracy
  • e.g., the following command checks for accuracy upto 6 decimal points or absolute error upto $10^-6$
kattis test -a 6

Submit a problem

  • make sure you've configured kattis-cli
kattis setup
  • see live results right on the terminal
cd <problem_id>
kattis submit

Result

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change. Please make sure to update tests as appropriate. Adding support for more languages is highly appreciated.

Using this Repo

  • clone this repo
  • create virtual environment with pypy 3.8 or higher
  • using conda the following command creates kattis virtual environment with pypy3.8
git clone git@github.com:rambasnet/kattis-cli.git
cd kattis-cli
pip install poetry
poetry install

Using conda and virtual environment

conda create -c conda-forge -n kattis pypy python=3.8
conda activate kattis
  • install dependencies
pip install -r requirements.txt
  • run the following command to install kattis-cli from this repo on Mac/Linux
make
./build.sh
pip install dist/kattis_cli-x.x.x-py3-none-any.whl --force-reinstall

Using Docker

  • clone this repo
  • run the following command to build and run the Dockerfile provided in this repo
  • if using Windows, run the following command in git-bash Terminal
docker-compose up -d
docker exec -it kattis-cli zsh

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kattis_cli-1.2.6.tar.gz (27.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kattis_cli-1.2.6-py3-none-any.whl (37.9 kB view details)

Uploaded Python 3

File details

Details for the file kattis_cli-1.2.6.tar.gz.

File metadata

  • Download URL: kattis_cli-1.2.6.tar.gz
  • Upload date:
  • Size: 27.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.13.5 Darwin/24.6.0

File hashes

Hashes for kattis_cli-1.2.6.tar.gz
Algorithm Hash digest
SHA256 ec09b4682700c9c2940bc12308d4b4969d47cf9effffb16af5d8e23e8d12a612
MD5 307212cf6784ee3304452ee515d80f77
BLAKE2b-256 72461fc325b8efe641a5204cf7d63bf1e63bc3241af7da9dbdd6bfa0398070e4

See more details on using hashes here.

File details

Details for the file kattis_cli-1.2.6-py3-none-any.whl.

File metadata

  • Download URL: kattis_cli-1.2.6-py3-none-any.whl
  • Upload date:
  • Size: 37.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.13.5 Darwin/24.6.0

File hashes

Hashes for kattis_cli-1.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 245b8b1ed4cba4fbf8018a651c983edc90728fba02387fc4e0c39a522fabd97a
MD5 61ce8181ed37cb1ee50182af1e02885c
BLAKE2b-256 91f964fc97f4b45683134b39ed7a6dde0bfb2e815cd67f90293a9a77b3ac8b0a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page