Skip to main content

Shared models and interfaces for finance datasources

Project description

pydantic-market-data

Shared Pydantic models and interfaces for financial data sources. Defines a standard contract (DataSource) and data structures (OHLCV, Symbol, History) to interoperability between finance packages.

Installation

pip install pydantic-market-data

Usage

Models

Standardized data models for financial entities.

from pydantic_market_data.models import Symbol, OHLCV, History, SecurityCriteria, Ticker

# Symbol Definition
s = Symbol(
    ticker="AAPL",
    name="Apple Inc.",
    exchange="NASDAQ",
    currency="USD"
)

# Historical Data Point
candle = OHLCV(
    date="2023-12-01", # Coerced to FlexibleDatetime
    open=150.0,
    high=155.0,
    low=149.0,
    close=154.0,
    volume=50000000
)

# Security Lookup Criteria
criteria = SecurityCriteria(
    symbol="AAPL",
    target_date="2023-12-01" # Coerced to FlexibleDate
)

Protocol

Implement the DataSource protocol to create compatible data providers.

from typing import Optional, List
from pydantic_market_data.interfaces import DataSource
from pydantic_market_data.models import SecurityCriteria, Symbol, History, Ticker, HistoryPeriod

class MySource(DataSource):
    def resolve(self, criteria: SecurityCriteria) -> Optional[Symbol]:
        # Implementation...
        pass

    def history(self, ticker: Ticker | str, period: HistoryPeriod = HistoryPeriod.MO1) -> History:
        # Implementation...
        pass

    def search(self, query: str) -> List[Symbol]:
        # Implementation...
        pass

CLI Support

The package provides optimized pydantic-settings models for building professional CLI tools.

from pydantic_market_data.cli_models import SearchArgs, PatchedCliSettingsSource
from pydantic_settings import BaseSettings

class MyCliSettings(BaseSettings):
    search: SearchArgs

    @classmethod
    def settings_customise_sources(cls, settings_cls, **kwargs):
        return (PatchedCliSettingsSource(settings_cls),)

# Usage:
# my-tool search --ticker AAPL --vv --format json

Key CLI features:

  • Clean Help: Automatically removes default values from help text for a cleaner look.
  • Improved Flags: Normalizes double-dash flags like --vv to -vv.
  • JSON Schema: Adds a --schema flag to output the interface definition.
  • Metavars: Custom types (SYMBOL, ISIN, etc.) provide descriptive help labels.

License

MIT

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

pydantic_market_data-0.1.16.tar.gz (91.6 kB view details)

Uploaded Source

Built Distribution

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

pydantic_market_data-0.1.16-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_market_data-0.1.16.tar.gz.

File metadata

  • Download URL: pydantic_market_data-0.1.16.tar.gz
  • Upload date:
  • Size: 91.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pydantic_market_data-0.1.16.tar.gz
Algorithm Hash digest
SHA256 8c769960c93f55df270a4f985169bb82001671f30ad0ced3332b9f040ac4ee2e
MD5 8f7834ea5d24b059f6018fce5dc2aba8
BLAKE2b-256 ae557537350dd85910e309d408686f56fad17dd1a43b3e074b2e0d1f4ad350f8

See more details on using hashes here.

File details

Details for the file pydantic_market_data-0.1.16-py3-none-any.whl.

File metadata

  • Download URL: pydantic_market_data-0.1.16-py3-none-any.whl
  • Upload date:
  • Size: 9.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pydantic_market_data-0.1.16-py3-none-any.whl
Algorithm Hash digest
SHA256 91b71033e1661da2c78069f79fa5e51d63a1346d950d0480fd1a176bcf754824
MD5 d906677037ce6c1993b6f28201d362aa
BLAKE2b-256 ada11c3f1896d3952580e3f9e841751161551b3e3534d4cd8868ed5260ed3238

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