Single source of truth for financial instrument data
Project description
Commodity Registry
Single source of truth for financial instrument data. Used to map ISINs, Tickers, and Names to canonical commodity identifiers for Beancount and other financial tools.
Concepts
- Canonical Name: The unique identifier used in Beancount ledgers (e.g.,
AAPL,CSPX). - ISIN: International Securities Identification Number (e.g.,
US0378331005). primary key for resolution. - FIGI: Financial Instrument Global Identifier.
- Ticker: Provider-specific symbol (e.g.,
AAPLfor Yahoo,CSPX.Lfor Yahoo).
Installation
uv tool install commodity-registry
Configuration
The registry loads data from two sources:
- Bundled Data: Built-in commodities (ETFs, Stocks).
- User Data: Custom YAML files located at
COMMODITY_REGISTRY_PATH.
Set the environment variable to point to your custom registry:
export COMMODITY_REGISTRY_PATH=~/path/to/my/registry
The registry recursively scans this directory for .yaml and .yml files.
Usage
Resolve a Token
Find the canonical commodity for an ISIN, Ticker, or Name.
commodity-reg resolve US0378331005
# Output: Resolved: AAPL
Automatic Currency Resolution
The registry programmatically resolves standard currencies to Yahoo tickers if they are not in your custom registry:
resolve EUR->EURUSD=Xresolve EUR/JPY->EURJPY=Xresolve USD/JPY->JPY=X
This eliminates the need to manually define standard Forex pairs in your registry files.
With price verification (checks if price matches historical data):
commodity-reg resolve US0378331005 --date 2024-01-01 --price 185.00
Add a Commodity
Add a new commodity to your local registry.
# Auto-fetch metadata from Yahoo Finance
commodity-reg add US0378331005 --fetch
# Manually specify details
commodity-reg add --name AAPL --isin US0378331005 --ticker AAPL --instrument-type Stock --asset-class Stock --currency USD
Linting
Validate your registry data and check for duplicates.
commodity-reg lint
Verify against live market data (checks if tickers are valid):
commodity-reg lint --verify
Fetch Metadata
Look up security details from online providers (Yahoo Finance, FT).
commodity-reg fetch --isin US0378331005
Programmatic Usage
You can use the registry in your Python scripts:
from commodity_registry.registry import get_registry
# Initialize registry (loads bundled data + user data from env var)
reg = get_registry()
# 1. Resolve by ISIN
commodity = reg.find_by_isin("US0378331005")
if commodity:
print(f"Name: {commodity.name}, Currency: {commodity.currency}")
# 2. Search by any token (ISIN, Name, FIGI)
candidates = reg.find_candidates("AAPL")
for c in candidates:
print(f"Found: {c.name} ({c.isin})")
# 3. Look up by ticker
# Note: Ticker lookup requires the provider name
comm = reg.find_by_ticker("yahoo", "AAPL")
Data Format (YAML)
commodities:
- name: AAPL
isin: US0378331005
instrument_type: Stock
asset_class: Stock
currency: USD
tickers:
yahoo: AAPL
validation_points:
- date: "2024-01-01"
price: 185.64
Contributing
- Bundled Data: Submit a PR to add common instruments to
src/commodity_registry/data/commodities/. - Providers: Implement new data sources in
src/commodity_registry/finder.pyby adding a class that implements theDataSourceinterface.
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 commodity_registry-0.2.0.tar.gz.
File metadata
- Download URL: commodity_registry-0.2.0.tar.gz
- Upload date:
- Size: 20.3 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
940c748574238fedbe731b49a35feefb5d61f0625d70f0694a914af0493c3ea1
|
|
| MD5 |
ccd11edb9ef509c2b6506422cf7fd1d7
|
|
| BLAKE2b-256 |
472973c8784db5d2cbb82c62d2352a160c0b5ed0d524bb38fb2c417f0273c3ed
|
File details
Details for the file commodity_registry-0.2.0-py3-none-any.whl.
File metadata
- Download URL: commodity_registry-0.2.0-py3-none-any.whl
- Upload date:
- Size: 22.7 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b807e22009e9db125a3bd60809e973000d588895ba8ec30141f1986cf19fb917
|
|
| MD5 |
58027e839de9e385d578247eb6ea1f26
|
|
| BLAKE2b-256 |
a5ec40fba481d9af31a3763840227cdd2cad4be0229726ab5847b52b440cd968
|