Skip to main content

A comprehensive Python client for Alpha Vantage API with configuration-driven endpoints

Project description

Alpha Vantage Client

A comprehensive, configuration-driven Python client for Alpha Vantage API with support for all endpoints including stocks, forex, crypto, commodities, economic indicators, and Alpha Intelligence features.

Features

  • Complete API Coverage: All Alpha Vantage endpoints including premium features
  • Configuration-Driven: Easy-to-use endpoint configuration system
  • Default Parameters: Set defaults at client initialization for cleaner code
  • Type Safety: Full type hints and validation
  • Developer-Friendly: Beautiful output formatting and comprehensive documentation
  • Easy Discovery: Built-in endpoint discovery and filtering

Supported Endpoints

📈 Time Series & Quotes

  • Intraday, daily, weekly, monthly time series
  • Real-time quotes and bulk quotes
  • Market status

📊 Technical Indicators

  • Moving averages (SMA, EMA, WMA, DEMA, TEMA, etc.)
  • Momentum indicators (RSI, MACD, Stochastic, etc.)
  • Trend indicators (ADX, Aroon, etc.)
  • Volatility indicators (Bollinger Bands, ATR, etc.)
  • Volume indicators (OBV, MFI, etc.)
  • And many more...

🏢 Fundamental Data

  • Company overview and financial statements
  • Earnings and dividends
  • ETF profiles and holdings
  • Options data

🌍 Economic Indicators

  • GDP, inflation, unemployment
  • Treasury yields, federal funds rate
  • Retail sales, durable goods
  • Nonfarm payroll

🛢️ Commodities

  • Energy (WTI, Brent, Natural Gas)
  • Metals (Copper, Aluminum)
  • Agriculture (Wheat, Corn, Cotton, Sugar, Coffee)

💱 Forex & Crypto

  • Currency exchange rates
  • Forex time series
  • Cryptocurrency data

🧠 Alpha Intelligence

  • News sentiment analysis
  • Earnings call transcripts
  • Insider transactions
  • Top gainers/losers
  • Advanced analytics (fixed and sliding window)

Installation

pip install alpha-vantage-client

Quick Start

from alpha_vantage_client import AlphaVantageClient

# Initialize with your API key
client = AlphaVantageClient(
    api_key="YOUR_API_KEY",
    default_symbol="AAPL",
    default_datatype="json"
)

# Get stock data
data = client.query("time_series_daily", symbol="AAPL")

# Get technical indicators
sma_data = client.query("sma", symbol="AAPL", interval="daily", series_type="close", time_period=20)

# Get economic data
gdp_data = client.query("real_gdp", interval="quarterly")

# Get news sentiment
news_data = client.query("news_sentiment", tickers="AAPL,TSLA", topics="technology")

Advanced Usage

Setting Defaults

client = AlphaVantageClient(
    api_key="YOUR_API_KEY",
    default_symbol="AAPL",
    default_datatype="json",
    default_interval="daily",
    default_series_type="close",
    default_time_period=20
)

# Now you can call methods without specifying common parameters
sma_data = client.query("sma")  # Uses defaults
rsi_data = client.query("rsi")  # Uses defaults

Discovering Endpoints

# Get all available endpoints
all_endpoints = client.get_available_endpoints()

# Get endpoints by category
economic_endpoints = client.get_available_endpoints(category="economic")
tech_indicators = client.get_available_endpoints(category="technical_indicators")

# Search for specific endpoints
gdp_endpoints = client.get_available_endpoints(filter_by="gdp")

# Get detailed information
detailed_info = client.get_available_endpoints(detailed=True, category="economic")

Advanced Analytics

# Fixed window analytics
analytics = client.query("analytics_fixed_window",
                        SYMBOLS="AAPL,MSFT,IBM",
                        RANGE="2023-07-01",
                        INTERVAL="DAILY",
                        CALCULATIONS="MEAN,STDDEV,CORRELATION")

# Sliding window analytics
sliding_analytics = client.query("analytics_sliding_window",
                                SYMBOLS="AAPL,IBM",
                                RANGE="2month",
                                INTERVAL="DAILY",
                                WINDOW_SIZE=20,
                                CALCULATIONS="MEAN,STDDEV(annualized=True)")

Configuration

The client supports extensive configuration options:

client = AlphaVantageClient(
    api_key="YOUR_API_KEY",
    # Time series defaults
    default_symbol="AAPL",
    default_interval="daily",
    default_outputsize="compact",
    default_datatype="json",
    
    # Technical indicator defaults
    default_series_type="close",
    default_time_period=20,
    
    # Other defaults
    default_adjusted=True,
    default_extended_hours=False
)

Error Handling

The client provides clear error messages and validation:

try:
    data = client.query("sma", symbol="INVALID", interval="invalid")
except ValueError as e:
    print(f"Validation error: {e}")
except RuntimeError as e:
    print(f"API error: {e}")

Development

Installation for Development

git clone https://github.com/yourusername/alpha-vantage-client.git
cd alpha-vantage-client
pip install -e ".[dev]"

Running Tests

pytest
pytest --cov=alpha_vantage_client

Code Formatting

black alpha_vantage_client/
flake8 alpha_vantage_client/
mypy alpha_vantage_client/

Documentation

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests
  5. Run the test suite
  6. Submit a pull request

License

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

Support

Acknowledgments

  • Alpha Vantage for providing the financial data APIs
  • The Python community for excellent tools and libraries

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

alpha_vantage_client-0.1.0.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

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

alpha_vantage_client-0.1.0-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: alpha_vantage_client-0.1.0.tar.gz
  • Upload date:
  • Size: 18.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for alpha_vantage_client-0.1.0.tar.gz
Algorithm Hash digest
SHA256 560a83fd32949b75e0c139e04e756934bf673d22f5214555184225c51d29b7c4
MD5 4a3f92fe5dbe0bc8112c345558024c87
BLAKE2b-256 f6f3367dd6641e4175bcaa334b66787257e122d50657316ddc24c4e51f36ef96

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for alpha_vantage_client-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 177e6295085b550fa5430b9168b575e6af65c7438d04e830bd59d5c941e48e8c
MD5 d6a8b06ccb33422ecb9ccd76214149c2
BLAKE2b-256 e9ca2296bfe3bacee9af145f2c91c2809f8308db7b5bdf09fdaa517d2914e02f

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