Skip to main content

A Python SDK for accessing UK Companies House API

Project description

UK Companies SDK

A modern Python SDK for accessing the UK Companies House API.

Features

  • Async-first: Built with modern async/await patterns for optimal performance
  • Type-safe: Full type hints and Pydantic models for data validation
  • Developer-friendly: Intuitive API with comprehensive documentation
  • Lightweight: Minimal dependencies, fast installation
  • Well-tested: Extensive test coverage with unit and integration tests
  • Automatic Retry: Smart retry logic with exponential backoff for rate-limited requests
  • Rate Limit Aware: Intelligent handling of API rate limits with configurable retry strategies

Installation

pip install ukcompanies

Quick Start

import asyncio
from ukcompanies import AsyncClient

async def main():
    # Initialize the client with your API key
    async with AsyncClient(api_key="your-api-key") as client:
        # Search for companies
        results = await client.search_companies("OpenAI")
        
        for company in results.items:
            print(f"{company.title} - {company.company_number}")
        
        # Get detailed company information
        company = await client.profile("12345678")
        print(f"Company: {company.company_name}")
        print(f"Status: {company.company_status}")

asyncio.run(main())

Configuration

API Key

You'll need an API key from Companies House. Get one by:

  1. Registering at Companies House Developer Hub
  2. Creating an application
  3. Getting your API key

Environment Variables

Create a .env file in your project root:

COMPANIES_HOUSE_API_KEY=your-api-key-here

Advanced Configuration

Retry Settings

The SDK automatically handles rate limits with intelligent retry logic. You can customize retry behavior:

from ukcompanies import AsyncClient

# Custom retry configuration
async with AsyncClient(
    api_key="your-api-key",
    auto_retry=True,        # Enable automatic retry (default: True)
    max_retries=5,          # Maximum retry attempts (default: 3)
    backoff="exponential",  # Backoff strategy: "exponential" or "fixed" (default: "exponential")
    base_delay=1.0,         # Base delay in seconds (default: 1.0)
    max_delay=60.0,         # Maximum delay between retries (default: 60.0)
    jitter_range=1.0,       # Random jitter range (default: 1.0)
    on_retry=my_callback    # Optional callback for retry events
) as client:
    # Use client here
    pass

# Custom retry callback
async def my_retry_callback(attempt, delay, response):
    print(f"Retry attempt {attempt} after {delay}s delay")

async with AsyncClient(
    api_key="your-api-key",
    on_retry=my_retry_callback
) as client:
    # Use client here
    pass

The SDK respects X-Ratelimit-Reset headers from the API for intelligent wait times and uses exponential backoff with jitter to prevent thundering herd problems.

Development

Setup

This project uses uv for dependency management:

# Install uv
curl -LsSf https://astral.sh/uv/install.sh | sh

# Install dependencies
uv pip install -e ".[dev]"

Testing

# Run tests
pytest

# Run tests with coverage
pytest --cov=ukcompanies

# Run type checking
mypy src/ukcompanies

# Run linting
ruff check src/ tests/

# Format code
ruff format src/ tests/

Documentation

Documentation is built with MkDocs:

# Install documentation dependencies
uv pip install -e ".[docs]"

# Serve documentation locally
mkdocs serve

# Build documentation
mkdocs build

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Links

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

ukcompanies-0.1.0.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

ukcompanies-0.1.0-py3-none-any.whl (34.6 kB view details)

Uploaded Python 3

File details

Details for the file ukcompanies-0.1.0.tar.gz.

File metadata

  • Download URL: ukcompanies-0.1.0.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for ukcompanies-0.1.0.tar.gz
Algorithm Hash digest
SHA256 fd9c59704b94a5cd50f33c23913c14f4c6f90819d939b93a1cceada4132dc92b
MD5 22ba313236f2511b441bfe64cab6dbd5
BLAKE2b-256 e829269b4d4160079368df2481d3d1ddbd615a48f297c930f1ad0255f0be14d6

See more details on using hashes here.

File details

Details for the file ukcompanies-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ukcompanies-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 34.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for ukcompanies-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c490e262ac8e88d87a463532ff6fe86d110ed12f90c3ac913f492b48f8e0692e
MD5 eebd3df56e270092c0aee01709c787cd
BLAKE2b-256 5a1fb180c998a980b19e89da99a345609f9d687a0d634973ba72427d4bc1661d

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