A Python package for tennis match scoring with support for various match formats
Project description
Python Tennis Scorer 🎾
A Python package for tennis match scoring with support for various match formats.
Try it live in your browser! No installation needed - our interactive documentation lets you experiment with PyTennisScorer directly in your browser using Pyodide.
Features
- Support for multiple match formats:
- Singles Grand Slam (Best of 5 sets)
- Singles ATP Finals (Best of 3 sets)
- Doubles Davis Cup (Best of 3 sets)
- Doubles ATP Tour (Best of 3 with match tiebreak)
- Doubles Grand Slam (Best of 3 with match tiebreak at 6-6 in final set)
- Standard tennis scoring (0, 15, 30, 40, Advantage)
- Tiebreak support (regular 7-point and match 10-point)
- Score parsing and formatting
- Undo functionality
- Immutable state management
Installation
pip install pytennisscorer
For development:
# Clone the repository
git clone <repository-url>
cd pytennisscorer
# Install with development dependencies
uv pip install -e ".[dev,notebook]"
Quick Start
from pytennisscorer import TennisScorer, MatchType
# Create a new scorer for a Grand Slam singles match
scorer = TennisScorer(MatchType.SINGLES_GRANDSLAM)
# Score points
scorer.increase_score(is_home=True) # Home player scores
scorer.increase_score(is_home=False) # Away player scores
# Get current score
print(scorer.get_score()) # Output: "0:0-15:15"
# Complete a game (home wins 4 points)
for _ in range(3):
scorer.increase_score(is_home=True)
print(scorer.get_score()) # Output: "1:0-0:0"
# Undo last point
scorer.undo()
print(scorer.get_score()) # Output: "0:0-40:15"
# Get winner (returns None while match is ongoing)
winner = scorer.get_winner() # Returns 'home', 'away', or None
Match Types
The package supports five different match formats:
MatchType.SINGLES_GRANDSLAM- Best of 5 sets (e.g., Wimbledon, US Open)MatchType.SINGLES_ATP_FINALS- Best of 3 sets with regular tiebreaksMatchType.DOUBLES_DAVISCUP- Best of 3 setsMatchType.DOUBLES_ATPTOUR- Best of 3 with match tiebreak and deciding pointMatchType.DOUBLES_GRANDSLAM- Best of 3 with match tiebreak at 6-6 in final set
Score Format
Scores are displayed in standard tennis notation:
- Game scores:
0,15,30,40,Ad(advantage) - Set and match:
6:4;3:6;2:2-30:15means:- First set: 6-4
- Second set: 3-6
- Third set: 2-2, current game 30-15
Examples
Complete Match Example
from pytennisscorer import TennisScorer, MatchType
# Start a doubles match
scorer = TennisScorer(MatchType.DOUBLES_DAVISCUP)
# Play a complete first set (6-4)
# Home wins 6 games, away wins 4 games
for game in range(10):
winner = game % 5 < 3 # Home wins 6, away wins 4
for _ in range(4):
scorer.increase_score(is_home=winner)
print(scorer.get_score()) # Output: "6:4;0:0-0:0"
# Check if match is finished
print(scorer.get_winner()) # Output: None (still playing)
Tiebreak Example
from pytennisscorer import TennisScorer, MatchType
scorer = TennisScorer(MatchType.DOUBLES_DAVISCUP)
# Create a scenario leading to tiebreak (6-6)
# ... score to 6-6 in games ...
# In tiebreak, scoring is numerical
scorer.increase_score(is_home=True)
print(scorer.get_score()) # Output: "6:6-1:0"
Development
Running Tests
# Run all tests
pytest
# Run with coverage
pytest --cov=src/pytennisscorer --cov-report=term-missing
# Run only unit tests
pytest -m unit
# Run only integration tests
pytest -m integration
Code Quality
# Format code
ruff format .
# Lint code
ruff check .
# Type checking
mypy src/pytennisscorer
Examples
See the Jupyter notebook in notebooks/tennis_scorer_examples.ipynb for interactive examples.
License
MIT License
Requirements
- Python 3.9+
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pytennisscorer-0.1.0.tar.gz.
File metadata
- Download URL: pytennisscorer-0.1.0.tar.gz
- Upload date:
- Size: 340.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bbda8b9bd4bb9843c619134594282451bb48e589252d8acfed7ccb504349ee74
|
|
| MD5 |
dd437601c95955fbf2b262a0f79fbe37
|
|
| BLAKE2b-256 |
5925226a6e7b7c70aca16e86c11d886484bb4c6335510cf5091e0fa34e460b01
|
Provenance
The following attestation bundles were made for pytennisscorer-0.1.0.tar.gz:
Publisher:
release.yml on talktennisdata/pytennisscorer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pytennisscorer-0.1.0.tar.gz -
Subject digest:
bbda8b9bd4bb9843c619134594282451bb48e589252d8acfed7ccb504349ee74 - Sigstore transparency entry: 707902959
- Sigstore integration time:
-
Permalink:
talktennisdata/pytennisscorer@7ec11ded99d79bf56c815af3ebae499036c31541 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/talktennisdata
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7ec11ded99d79bf56c815af3ebae499036c31541 -
Trigger Event:
release
-
Statement type:
File details
Details for the file pytennisscorer-0.1.0-py3-none-any.whl.
File metadata
- Download URL: pytennisscorer-0.1.0-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dcbc2c02ef5ac870b2a8cab120f2a190db530c9a8c71af1da682556795dda23a
|
|
| MD5 |
fb49ef966a268b3393eb851d0328d634
|
|
| BLAKE2b-256 |
367e2e5af10651783efb775a82ee969b2510553134c01508de84066265a21d6e
|
Provenance
The following attestation bundles were made for pytennisscorer-0.1.0-py3-none-any.whl:
Publisher:
release.yml on talktennisdata/pytennisscorer
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pytennisscorer-0.1.0-py3-none-any.whl -
Subject digest:
dcbc2c02ef5ac870b2a8cab120f2a190db530c9a8c71af1da682556795dda23a - Sigstore transparency entry: 707902961
- Sigstore integration time:
-
Permalink:
talktennisdata/pytennisscorer@7ec11ded99d79bf56c815af3ebae499036c31541 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/talktennisdata
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7ec11ded99d79bf56c815af3ebae499036c31541 -
Trigger Event:
release
-
Statement type: