Skip to main content

A simple python utility library for representing cryptocurrency amounts

Project description

cryptils

Tests Coverage License PyPI TestPyPI

An utility library for representing cryptocurrency amounts in Python.

Installation

pip install cryptils

Quick Start

from cryptils import BTC, ETH, USDC, USDT

# Create amounts with exact decimal precision
btc = BTC("1.5")
print(btc)  # 1.50000000 BTC

eth = ETH("2.0")
print(eth)  # 2.000000000000000000 ETH

# Arithmetic with other amounts
result = BTC("0.5") + BTC("0.25")
print(result)  # 0.75000000 BTC

# Arithmetic with built-in types (int, float, Decimal)
from decimal import Decimal

btc = BTC("1.0")
print(btc + 0.5)  # 1.50000000 BTC (added float)
print(btc + 2)  # 3.00000000 BTC (added int)
print(btc + Decimal("0.5"))  # 1.50000000 BTC (added Decimal)
print(2 * btc)  # 2.00000000 BTC (int * BTC)
print(10 - BTC("2.5"))  # 7.50000000 BTC (int - BTC)

# Different currencies maintain their own precision
usdc = USDC("100")
print(usdc)  # 100.000000 USDC

# Access the raw Decimal value
print(btc.to_decimal())  # Decimal('1.50000000')

# Get the formatted string explicitly
print(btc.to_string())  # 1.50000000 BTC

Features

  • Uses decimal.Decimal internally to avoid floating-point errors.
  • Consistent precision handling per currency (e.g., 8 decimals for BTC, 6 for USDC).
  • Simple, explicit API designed for financial precision.

Pydantic Support

CryptoAmount subclasses work as Pydantic v2 field types:

from pydantic import BaseModel
from cryptils import BTC, ETH, USDC

class WalletBalance(BaseModel):
    btc: BTC
    eth: ETH
    usdc: USDC

wallet = WalletBalance(btc="1.5", eth=2, usdc=100.0)
print(wallet.model_dump_json())
# {"btc":"1.50000000","eth":"2.000000000000000000","usdc":"100.000000"}

Requires Pydantic v2 (pip install pydantic).

Development

This project uses uv for environment management, ruff for linting and formatting, and tox for testing across Python versions.

# Setup environment
uv sync

# Run tests
uv run pytest

# Run tests across all supported Python versions
uv run tox

# Format and lint
uv run ruff check --fix .
uv run ruff format .

# Install pre-commit hooks
uv run pre-commit install

# Run pre-commit on all files
uv run pre-commit run --all-files

License

This project is licensed under the terms of the MIT license.

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

cryptils-0.1.0a4.tar.gz (53.3 kB view details)

Uploaded Source

Built Distribution

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

cryptils-0.1.0a4-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

Details for the file cryptils-0.1.0a4.tar.gz.

File metadata

  • Download URL: cryptils-0.1.0a4.tar.gz
  • Upload date:
  • Size: 53.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cryptils-0.1.0a4.tar.gz
Algorithm Hash digest
SHA256 f26158476c88234520efcb801e317079527c8cc23efee6d0c1bdbe0af9cddaba
MD5 8d2ba292e312e2ba9dc5b320f5b893c0
BLAKE2b-256 05c616eca300c0b9cdae1e28261e50dda78321c4e12c77f56162db5ba77c08ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for cryptils-0.1.0a4.tar.gz:

Publisher: publish-pypi.yml on seba3c/cryptils

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cryptils-0.1.0a4-py3-none-any.whl.

File metadata

  • Download URL: cryptils-0.1.0a4-py3-none-any.whl
  • Upload date:
  • Size: 6.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cryptils-0.1.0a4-py3-none-any.whl
Algorithm Hash digest
SHA256 28fe4a9a181e60d2eb396a98240ffc5a5b2ef688c1ab1d489b7b6f36cd79d33b
MD5 8ea1dbd2b489d831a84d441a16723561
BLAKE2b-256 c0306dae216d386185a269f7fe3b457499e5ce952b661b20c4a274971979e38e

See more details on using hashes here.

Provenance

The following attestation bundles were made for cryptils-0.1.0a4-py3-none-any.whl:

Publisher: publish-pypi.yml on seba3c/cryptils

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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