Skip to main content

Multi-market OHLCV data SDK with AI context builder and LLM integration for Vietnamese stocks, US stocks, crypto, and commodities

Project description

aipriceaction

Python SDK for AIPriceAction — OHLCV data access and AI context builder for multi-market investment analysis. Reads from a public S3 archive (no API credentials needed).

Install

pip install aipriceaction

Data Sources

The SDK reads OHLCV data from an S3-compatible archive. All sources are auto-detected from ticker metadata — no need to specify which market a ticker belongs to.

Source Examples Intervals
Vietnamese stocks (VCI) VCB, FPT, VNINDEX 1m, 1h, 1D
US / international stocks (Yahoo) AAPL, GOOGL, GC=F 1m, 1h, 1D
Cryptocurrency (Binance) BTCUSDT, ETHUSDT 1m, 1h, 1D
SJC gold SJC-GOLD 1D

Quick Start

from aipriceaction import AIPriceAction

client = AIPriceAction()

# Ticker metadata
tickers = client.get_tickers()            # all tickers
tickers = client.get_tickers(source="vn") # filter by source

# OHLCV data as DataFrame
df = client.get_ohlcv("VCB", interval="1D")                         # VN stock
df = client.get_ohlcv("AAPL", interval="1D")                        # US stock
df = client.get_ohlcv("BTCUSDT", interval="1D")                     # crypto
df = client.get_ohlcv(tickers=["VCB", "FPT", "BTCUSDT"], interval="1D")  # mixed

# Date range, limit, MA indicators
df = client.get_ohlcv("VCB", start_date="2025-01-01", end_date="2025-04-30", ma=True)
df = client.get_ohlcv("VCB", interval="1D", limit=100, ema=True)    # EMA instead of SMA

Override the S3 endpoint if self-hosting:

client = AIPriceAction(base_url="https://your-s3-endpoint/archive")

Data is cached to disk by default (temp dir). Set cache_dir for persistent caching:

client = AIPriceAction(cache_dir="./cache")

AI Context Builder

Build structured context strings for LLM-powered investment analysis.

from aipriceaction import AIContextBuilder

builder = AIContextBuilder(lang="en")

# Single ticker (VNINDEX included as reference by default)
context = builder.build(ticker="VCB", interval="1D")

# Multi ticker
context = builder.build(tickers=["VCB", "FPT", "TCB"], interval="1D")

# No data — system prompt + disclaimer only
context = builder.build()

# Omit VNINDEX reference
context = builder.build(ticker="VCB", interval="1D", reference_ticker=None)

Browse Question Bank

for q in builder.questions("single"):
    print(f"{q['title']}: {q['snippet']}")

Ask LLM

Requires OPENAI_API_KEY (or MOCK_ONLY=true env var). The context is built once and reused across answer() calls for KV cache efficiency.

builder.build(ticker="VCB", interval="1D")

response = builder.answer("What is the current trend?")
follow_up = builder.answer("What is the support level?")  # faster, KV cache hit

Configuration

Set via environment variables or .env file:

Variable Default Description
OPENAI_API_KEY "" API key for LLM calls
OPENAI_BASE_URL https://openrouter.ai/api/v1 LLM API endpoint
OPENAI_MODEL openai/gpt-oss-20b Default LLM model
ANTHROPIC_API_KEY "" Anthropic API key
MOCK_ONLY false Skip API validation
AI_CONTEXT_LANG en Context language (en or vi)

OpenRouter Models

Curated free-tier models available via OpenRouter:

from aipriceaction.llm_models import OpenRouter

for m in OpenRouter.FREE:
    print(f"{m.id}{m.label}")

Examples

Build context

from aipriceaction import AIContextBuilder

builder = AIContextBuilder(lang="en")

# Single ticker — prints questions, then full context
builder.build(ticker="VCB", interval="1D")
print(builder._last_context)

Multi-ticker context

builder.build(tickers=["VCB", "FPT", "TCB"], interval="1D")
print(builder._last_context)

System prompt only (no market data)

context = builder.build()
print(context)

Build context + call LLM

Build once, ask multiple questions — the second call is faster due to LLM KV cache.

from aipriceaction import AIContextBuilder

builder = AIContextBuilder(lang="en")

# Build context once
builder.build(ticker="VCB", interval="1D")

# First question (cold)
response1 = builder.answer("What is the current trend?")

# Follow-up (warm — same context prefix, KV cache hit)
response2 = builder.answer("What is the support level?")

Multi-timeframe analysis

Switch timeframe between questions. Pass previous responses as history so the LLM can cross-reference timeframes.

from aipriceaction import AIContextBuilder

builder = AIContextBuilder(lang="en")

# Daily context — big picture
builder.build(ticker="VIC", interval="1D")
daily_response = builder.answer("What is the weekly trend?")

# Hourly context — intraday detail, with daily analysis as history
builder.build(ticker="VIC", interval="1h")
hourly_response = builder.answer(
    "Confirm or reject the daily trend using intraday data.",
    history=[daily_response],
)

More examples in examples/:

Example Description
single_ticker.py Build context for one ticker
multi_ticker.py Build context for multiple tickers
multi_timeframe.py Multi-timeframe: daily + hourly with history
reference_ticker.py Context with VNINDEX reference
llm_question.py Build context + call LLM
system_prompt_only.py System prompt without ticker data

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

aipriceaction-0.1.0.tar.gz (44.4 kB view details)

Uploaded Source

Built Distribution

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

aipriceaction-0.1.0-py3-none-any.whl (44.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: aipriceaction-0.1.0.tar.gz
  • Upload date:
  • Size: 44.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.20

File hashes

Hashes for aipriceaction-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1e71fe056ddb43a8a1c62c909d498011e7ce31c982971894a7b480d9a067bd0b
MD5 f4874dc3f6dc178e0666205c9373937c
BLAKE2b-256 83f2eae86d1d593da5fdb473adc87958955eb79bd46a9f854337b52bed35eccf

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for aipriceaction-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8d2d2c61fc20f723a3762fa81e9d678ab62f63e1806775cd77c05d0628116c47
MD5 5cdafd357ffa7b23e5c7ca482341b9eb
BLAKE2b-256 5ee992eacbad3b3f48d54edfe198e51aa96cd4b08e833e879084178d8e37004c

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