The US Stock Market Ticks Data API provides granular tick data for all US equities spanning across all exchanges.

It includes current and delisted companies, encompassing approximately 80,000 tickers, 16,000+ securities are updated daily. The total data size is approximately 10 terabytes.

The dataset begins from January 1st, 2008, and is updated until the current date.

Quick Start

Test Drive with "DEMO" Key
  1. You can start with “DEMO” API key to test the data for a few tickers only: AAPL.US, TSLA.US, VTI.US, AMZN.US, BTC-USD and EUR-USD. For these tickers, all of our types of data (APIs), including Real-Time Data, are available without limitations.
  2. Register for the free plan to receive your API key (limited to 20 API calls per day) with access to End-Of-Day Historical Stock Market Data API for any ticker, but within the past year only. Plus a List of tickers per Exchange is available.
  3. We recommend to explore our plans, starting from $19.99, to access the necessary type of data without limitations.

To get historical stock tick data, use the following URL:

URL
cURL
PHP
Python
R
https://eodhd.com/api/ticks/?s=AAPL&from=1694455200&to=1694541600&limit=1&api_token=demo&fmt=json
curl --location "https://eodhd.com/api/ticks/?s=AAPL&from=1694455200&to=1694541600&limit=1&api_token=demo&fmt=json"
$curl = curl_init();

curl_setopt_array($curl, array(
    CURLOPT_URL => 'https://eodhd.com/api/ticks/?s=AAPL&from=1694455200&to=1694541600&limit=1&api_token=demo&fmt=json',
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_ENCODING => '',
    CURLOPT_MAXREDIRS => 10,
    CURLOPT_TIMEOUT => 0,
    CURLOPT_FOLLOWLOCATION => true,
    CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
    CURLOPT_CUSTOMREQUEST => 'GET',
));

$data = curl_exec($curl);
curl_close($curl);

try {
    $data = json_decode($data, true, 512, JSON_THROW_ON_ERROR);
    var_dump($data);
} catch (Exception $e) {
    echo 'Error. '.$e->getMessage();
}
import requests

url = f'https://eodhd.com/api/ticks/?s=AAPL&from=1694455200&to=1694541600&limit=1&api_token=demo&fmt=json'
data = requests.get(url).json()

print(data)
library(httr)
library(jsonlite)

url <- 'https://eodhd.com/api/ticks/?s=AAPL&from=1694455200&to=1694541600&limit=1&api_token=demo&fmt=json'
response <- GET(url)

if (http_type(response) == "application/json") {
    content <- content(response, "text", encoding = "UTF-8")
    cat(content)
} else {
    cat("Error while receiving data\n")
}
  • s – symbol, for example, AAPL.US, consists of two parts: {SYMBOL_NAME}.{EXCHANGE_ID}. This API works only for US exchanges for the moment, then you can use ‘AAPL’ or ‘AAPL.US’ to get the data as well for other US tickers.
  • api_token – your own API KEY, which you will get after you subscribe to our services.
  • from and to – use these parameters to filter data by datetime. Parameters should be passed in UNIX time with UTC timezone, for example, these values are correct: “from=1694455200&to=1694541600” and correspond to ‘ 2023-09-11 18:00:00 ‘ and ‘ 2023-09-12 18:00:00 ‘.
  • limit – the maximum number of ticks to be provided.

For testing purposes, you can try the following API Key (works only for AAPL.US ticker): demo

Output

JSON response example:

tick data example
US Tick Data Financial APIs

Where the fields are:

  • mkt – market where trade took place
  • price – the price of the transaction
  • seq – trade sequence number
  • shares – shares in transaction
  • sl – sales condition
  • ts -timestamp
  • sub_mkt – sub-market where trade took place

Trading codes

@  – Regular Sale
A – Acquisition
B – Bunched Trade
C  – Cash Sale
D  – Distribution
E  – Placeholder
F – Intermarket Sweep
G – Bunched Sold Trade
H – Price Variation Trade
I – Odd Lot Trade
K – Rule 155 Trade (AMEX)
L – Sold Last
M – Market Center Official Close
N – Next Day
O – Opening Prints
P – Prior Reference Price
Q – Market Center Official Open
R – Seller
S – Split Trade
T – Form T
U – Extended trading hours (Sold Out of Sequence)
V – Contingent Trade
W – Average Price Trade
X – Cross/Periodic Auction Trade
Y – Yellow Flag Regular Trade
Z – Sold (out of sequence)

Sign up & Get Data

You can also check our Intraday Data API and Real-Time Data API via WebSockets.