Official Python SDK for the SentiSense market intelligence API
Project description
SentiSense Python SDK
Official Python SDK for the SentiSense market intelligence API.
Installation
pip install sentisense
Quick Start
from sentisense import SentiSenseClient
client = SentiSenseClient("your-api-key")
# Get a stock price
price = client.get_stock_price("AAPL")
print(price)
# Get multiple stock prices
prices = client.get_stock_prices(["AAPL", "MSFT", "GOOGL"])
# Check market status
status = client.get_market_status()
print(status)
# Get latest news for a stock
news = client.get_documents_by_ticker("TSLA", source="news", days=7)
# Search across news and social media
results = client.search_documents("AI earnings surprise")
# Get mention time series for a stock (v2 metrics API)
mentions = client.get_metrics("NVDA", metric_type="mentions")
# Get sentiment time series
sentiment = client.get_metrics("NVDA", metric_type="sentiment")
# Get mentions broken down by source
dist = client.get_metrics_distribution("NVDA", metric_type="mentions", dimension="source")
Authentication
All API requests require an API key. You can generate one from your Developer Console.
client = SentiSenseClient("your-api-key")
For full endpoint documentation, request/response schemas, and interactive examples, see the API Documentation.
API Reference
Stocks
| Method | Description |
|---|---|
get_stock_price(ticker) |
Real-time price for a single stock |
get_stock_prices(tickers) |
Real-time prices for multiple stocks |
get_stock_profile(ticker) |
Company profile |
get_stock_chart(ticker, timeframe="1M") |
OHLCV chart data |
get_all_stocks() |
List of available tickers |
get_all_stocks_detailed() |
Tickers with company names and entity IDs |
get_market_status() |
Market open/closed status |
get_fundamentals(ticker, timeframe="quarterly") |
Financial fundamentals |
News & Documents
| Method | Description |
|---|---|
get_documents_by_ticker(ticker, source?, days?, hours?, limit?) |
News and social posts for a stock |
get_documents_by_ticker_range(ticker, start_date, end_date) |
Documents within a date range |
get_documents_by_entity(entity_id) |
Documents for a KB entity |
search_documents(query, source?, days?, limit?) |
Natural language search across news and social |
get_documents_by_source(source, days?, hours?, limit?) |
Latest from a source ("news", "reddit", "x", "substack") |
get_stories(limit?, days?, expanded?) |
AI-curated news story clusters |
get_story(cluster_id) |
Single story with all source documents |
get_stories_by_ticker(ticker, limit?) |
Stories for a specific stock |
Metrics (v2)
| Method | Description |
|---|---|
get_metrics(symbol, metric_type="mentions", start_time?, end_time?, max_data_points?) |
Time series for a metric (mentions, sentiment, sentisense_score, social_dominance, creators) |
get_metrics_distribution(symbol, metric_type="mentions", dimension="source", start_time?, end_time?) |
Metric distribution by dimension (e.g. mentions by source) |
Note:
start_timeandend_timeare epoch milliseconds.
Sentiment & Mentions (deprecated)
The following methods hit the v1 entity-metrics endpoints which return empty data. Use the v2 metrics methods above instead.
| Method | Description |
|---|---|
get_mentions(symbol, source?, start_date?, end_date?) |
Mention data across news and social |
get_mention_count(symbol, source?, start_date?, end_date?) |
Total mention count |
get_mention_count_by_source(symbol, start_date?, end_date?) |
Mentions broken down by source |
get_sentiment(symbol, start_date?, end_date?) |
Sentiment data for a stock |
get_sentiment_by_source(symbol, date?) |
Sentiment broken down by source |
get_average_sentiment(symbol, start_date?, end_date?) |
Average sentiment score |
Institutional Flows (13F)
| Method | Description |
|---|---|
get_institutional_quarters() |
Available 13F reporting quarters |
get_institutional_flows(report_date, limit=50) |
Fund flows for a quarter |
get_stock_holders(ticker, report_date) |
Institutional holders for a stock |
get_activist_positions(report_date) |
Activist investor positions |
Analyst Ratings
The price target cone (mean, high, low, upside %) and consensus are free for everyone, full data via API — we give it away. Upgrade/downgrade feeds and forward EPS estimates are limited on free, unlimited on PRO.
| Method | Description |
|---|---|
get_analyst_consensus(ticker) |
Price target band (mean, high, low), analyst count, upside %. Free for everyone, full data. |
get_analyst_actions(ticker, lookback_days=90) |
Recent upgrade/downgrade actions. Free: 3 most recent. PRO: unlimited. |
get_analyst_estimates(ticker) |
Forward EPS estimates and earnings surprise history. Free: 1 quarter. PRO: full history. |
get_analyst_market_activity(lookback_days=30) |
Market-wide recent analyst actions across all tickers (PRO). |
Company KPIs (PRO)
| Method | Description |
|---|---|
get_company_kpis(ticker) |
Company-specific KPI time-series (product metrics, segment revenue). Free tier returns metadata only (empty kpis array); PRO returns full series. |
list_kpi_coverage() |
List all tickers with curated KPI coverage (free, no quota cost) |
ETFs (beta)
Composition data is public; the holdings-weighted aggregate views follow the same PRO-with-preview pattern as Analyst/Insider. Aggregates synthesize fund-level views from each constituent's per-stock data (analyst coverage, insider trades, sentiment), weighted by allocation. Every aggregate response carries a coverage block so you see exactly how much of the fund's AUM the underlying data covered.
| Method | Description |
|---|---|
list_etfs() |
Every ETF tracked by SentiSense. Returns ticker, fund name, issuer, tracked index, asset class. |
get_etf_holdings(ticker) |
Full composition: per-holding weights and freshness metadata. |
get_etf_analyst_aggregate(ticker) |
Holdings-weighted analyst consensus (weighted upside, distribution). Free: headline + coverage. PRO: + topContributors. |
get_etf_insider_aggregate(ticker, lookback_days=30) |
Holdings-weighted Form 4 net flow over a configurable window. Free: headline + buy/sell split. PRO: + topContributors. |
get_etf_sentiment_aggregate(ticker) |
Two SentiSense readings side-by-side: constituent-weighted and direct (mentions of the fund itself). |
Error Handling
The SDK raises typed exceptions for API errors:
from sentisense import SentiSenseClient, AuthenticationError, RateLimitError
client = SentiSenseClient("your-api-key")
try:
price = client.get_stock_price("AAPL")
except AuthenticationError:
print("Invalid or missing API key")
except RateLimitError:
print("Rate limit exceeded, try again later")
| Exception | HTTP Status | Description |
|---|---|---|
AuthenticationError |
401, 403 | Invalid or missing API key |
NotFoundError |
404 | Resource not found |
RateLimitError |
429 | Rate limit exceeded |
APIError |
Other 4xx/5xx | General API error |
All exceptions inherit from SentiSenseError and include .status_code, .message, and .response attributes.
License
MIT - see LICENSE for details.
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 sentisense-0.15.0.tar.gz.
File metadata
- Download URL: sentisense-0.15.0.tar.gz
- Upload date:
- Size: 22.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0ffe8975c4c7dcc8561854eb802de0619b49f96ece2987090d3c28da22eea623
|
|
| MD5 |
03c553f65826563ba439f7969f00fda1
|
|
| BLAKE2b-256 |
3da2994c4c355f3b9e733c91da6d2190eab0005f9a091186e39e161a1b989f67
|
File details
Details for the file sentisense-0.15.0-py3-none-any.whl.
File metadata
- Download URL: sentisense-0.15.0-py3-none-any.whl
- Upload date:
- Size: 19.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd853ed0868c668935fbb0f82d7ab5064c5c5fd209b5f13978d00193f3747d9d
|
|
| MD5 |
965168ce525641ab636af4596ed893c8
|
|
| BLAKE2b-256 |
c6e2dfbfcdea419ac3d2c7eadba40bf9386d0ebaacde15a12c03cf79a8eb3a05
|