A structured Python interface for retrieving and validating market data using yfinance
Project description
yfinance
A structured Python interface for retrieving and validating market data using yfinance.
Implements the DataSource protocol from pydantic-market-data to provide type-safe security resolution and historical data fetching.
Features
- Protocol-Oriented: Implements
DataSourceinterface. - Security Resolution: Resolve ISINs and Symbols to valid
yfinancetickers. - Validation:
- Price Validation: Verify tickers against daily high/low range.
- Date Validation: Validate prices on specific historical dates.
- CLI: Optional command-line interface for lookup and history.
Installation
# Basic installation
uv pip install yfinance
Usage
As a Library
from py_yfinance.source import YFinanceDataSource
from pydantic_market_data.models import SecurityCriteria
source = YFinanceDataSource()
# 1. Simple Lookup by Symbol
criteria = SecurityCriteria(symbol="AAPL")
result = source.resolve(criteria)
print(result)
# Symbol(ticker='AAPL', name='Apple Inc.', exchange='NMS', currency='USD', ...)
# 2. Strict Validation using Date & Price
# Useful for verifying ISIN mappings or ensuring data quality
criteria = SecurityCriteria(
isin="NL0010273215",
target_date="2025-12-15",
target_price=923.4 # Validates against history
)
match = source.resolve(criteria)
if match:
print(f"Verified: {match.ticker}")
else:
print("Validation failed: Price mismatch or symbol not found")
CLI Usage
Lookup
Resolve a security by Symbol or ISIN.
# Basic Lookup
uv run yfinance lookup --symbol AAPL
# ISIN Lookup with Strict Validation
# Verifies that NL0010273215 commanded a price of ~923.4 on 2025-12-15
uv run yfinance lookup --isin NL0010273215 --date 2025-12-15 --price 923.4
History
Fetch historical candles.
uv run yfinance history AAPL --period 5d
Development
This project uses uv for dependency management.
# Sync dependencies
uv sync
# Run Tests
uv run pytest
License
MIT
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 py_yfinance-0.1.13.tar.gz.
File metadata
- Download URL: py_yfinance-0.1.13.tar.gz
- Upload date:
- Size: 12.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1ea846b4ec5013e56f4612ec071f9497541ad8b08ec6a761ffdff1695de92d1b
|
|
| MD5 |
c9d8c711021219b63f069187a590fded
|
|
| BLAKE2b-256 |
6a255abcdf68f2bc444a22590c148afbdb82a9436456761c7c83aed2854506b6
|
File details
Details for the file py_yfinance-0.1.13-py3-none-any.whl.
File metadata
- Download URL: py_yfinance-0.1.13-py3-none-any.whl
- Upload date:
- Size: 9.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b28640e805f1e967c71bb3cf167acfaf0b3522b72cd2ea6f9b64eef6659d05bd
|
|
| MD5 |
bafcf49c74814a51ffb03c7701b97b63
|
|
| BLAKE2b-256 |
19c218cbefea14530a509d8b64ab04bc181f9a39af8921cda7ea0f806377f9da
|