Sub-commands:
collect-alpaca
collect securities listings from Alpaca and store in securities master database
quantrocket master collect-alpaca [-h]
Collect securities listings from Alpaca and store in securities master
database.
Examples:
quantrocket master collect-alpaca
collect-edi
collect securities listings from EDI and store in securities master database
quantrocket master collect-edi [-h] [-e [MIC [MIC ...]]]
Named Arguments
- -e, --exchanges
collect listings for these exchanges (identified by MICs)
Collect securities listings from EDI and store in securities master
database.
Examples:
Collect sample listings:
quantrocket master collect-edi –exchanges FREE
Collect listings for all permitted exchanges
quantrocket master collect-edi
Collect all Chinese stock listings:
quantrocket master collect-edi -e XSHG XSHE
collect-figi
collect securities listings from Bloomberg OpenFIGI and store in securities master database
quantrocket master collect-figi [-h]
Collect securities listings from Bloomberg OpenFIGI and store
in securities master database.
OpenFIGI provides several useful security attributes including
market sector, a detailed security type, and share class-level
FIGI identifier.
The collected data fields show up in the master file under the
prefix “figi_*”.
This command does not directly query the OpenFIGI API but rather
downloads a dump of all FIGIs which QuantRocket has previously
mapped to securities from other vendors.
Examples:
quantrocket master collect-figi
collect-ibkr
collect securities listings from Interactive Brokers and store in securities master database
quantrocket master collect-ibkr [-h] [-e [EXCHANGE [EXCHANGE ...]]]
[-t [SEC_TYPE [SEC_TYPE ...]]]
[-c [CURRENCY [CURRENCY ...]]]
[-s [SYMBOL [SYMBOL ...]]]
[-u [UNIVERSE [UNIVERSE ...]]]
[-i [SID [SID ...]]]
Named Arguments
- -e, --exchanges
one or more exchange codes to collect listings for (required unless providing universes or sids). For sample data use exchange code ‘FREE’
- -t, --sec-types
Possible choices: STK, ETF, FUT, CASH, IND
limit to these security types. Possible choices: [‘STK’, ‘ETF’, ‘FUT’, ‘CASH’, ‘IND’]
- -c, --currencies
limit to these currencies
- -s, --symbols
limit to these symbols
- -u, --universes
limit to these universes
- -i, --sids
limit to these sids
Collect securities listings from Interactive Brokers and store in
securities master database.
Specify an exchange (optionally filtering by security type, currency,
and/or symbol) to collect listings from the IBKR website and collect
associated contract details from the IBKR API. Or, specify universes or
sids to collect details from the IBKR API, bypassing the website.
Examples:
Collect free sample listings:
quantrocket master collect-ibkr –exchanges FREE
Collect all Toronto Stock Exchange stock listings:
quantrocket master collect-ibkr –exchanges TSE –sec-types STK
Collect all NYSE ARCA ETF listings:
quantrocket master collect-ibkr -e ARCA –sec-types ETF
Collect specific symbols from Nasdaq:
quantrocket master collect-ibkr -e NASDAQ –symbols AAPL GOOG NFLX
Re-collect contract details for an existing universe called “japan-fin”:
quantrocket master collect-ibkr –universes japan-fin
collect-sharadar
collect securities listings from Sharadar and store in securities master database
quantrocket master collect-sharadar [-h] [-c [COUNTRY [COUNTRY ...]]]
Named Arguments
- -c, --countries
Possible choices: US, FREE
collect listings for these countries. Possible choices: [‘US’, ‘FREE’]
Default: [‘US’]
Collect securities listings from Sharadar and store in securities master
database.
Examples:
Collect sample listings:
quantrocket master collect-sharadar –countries FREE
Collect all US listings:
quantrocket master collect-sharadar –countries US
collect-usstock
collect US stock listings from QuantRocket and store in securities master database
quantrocket master collect-usstock [-h]
Collect US stock listings from QuantRocket and store in securities master
database.
Examples:
quantrocket master collect-usstock
collect-ibkr-options
collect IBKR option chains for underlying securities
quantrocket master collect-ibkr-options [-h] [-u [UNIVERSE [UNIVERSE ...]]]
[-i [SID [SID ...]]] [-f INFILE]
Named Arguments
- -u, --universes
collect options for these universes of underlying securities
- -i, --sids
collect options for these underlying sids
- -f, --infile
collect options for the sids in this file (specify ‘-‘ to read file from stdin)
Collect IBKR option chains for underlying securities.
Note: option chains often consist of hundreds, sometimes thousands of options
per underlying security. Be aware that requesting option chains for large
universes of underlying securities, such as all stocks on the NYSE, can take
numerous hours to complete.
Examples:
Collect option chains for several underlying securities:
quantrocket master collect-ibkr-options –sids FIBBG000LV0836 FIBBG000B9XRY4
Collect option chains for NQ futures:
quantrocket master get -e GLOBEX -s NQ -t FUT | quantrocket master collect-ibkr-options -f -
Collect option chains for a large universe of stocks called “nyse-stk” (see note above):
quantrocket master collect-ibkr-options -u “nyse-stk”
get
query security details from the securities master database and download to file
quantrocket master get [-h] [-e [EXCHANGE [EXCHANGE ...]]]
[-t [SEC_TYPE [SEC_TYPE ...]]]
[-c [CURRENCY [CURRENCY ...]]]
[-u [UNIVERSE [UNIVERSE ...]]]
[-s [SYMBOL [SYMBOL ...]]] [-i [SID [SID ...]]]
[--exclude-universes [UNIVERSE [UNIVERSE ...]]]
[--exclude-sids [SID [SID ...]]] [--exclude-delisted]
[--exclude-expired] [-m] [-v [VENDOR [VENDOR ...]]]
[-o OUTFILE] [-j] [-f [FIELD [FIELD ...]]]
filtering options
- -e, --exchanges
limit to these exchanges. You can specify exchanges using the MIC or the vendor’s exchange code.
- -t, --sec-types
Possible choices: STK, ETF, FUT, CASH, IND, OPT, FOP, BAG
limit to these security types. Possible choices: [‘STK’, ‘ETF’, ‘FUT’, ‘CASH’, ‘IND’, ‘OPT’, ‘FOP’, ‘BAG’]
- -c, --currencies
limit to these currencies
- -u, --universes
limit to these universes
- -s, --symbols
limit to these symbols
- -i, --sids
limit to these sids
- --exclude-universes
exclude these universes
- --exclude-sids
exclude these sids
- --exclude-delisted
exclude delisted securities (default is to include them)
Default: False
- --exclude-expired
exclude expired contracts (default is to include them)
Default: False
- -m, --frontmonth
exclude backmonth and expired futures contracts
Default: False
- -v, --vendors
Possible choices: alpaca, edi, ibkr, sharadar, usstock
limit to these vendors. Possible choices: [‘alpaca’, ‘edi’, ‘ibkr’, ‘sharadar’, ‘usstock’]
output options
- -o, --outfile
filename to write the data to (default is stdout)
- -j, --json
format output as JSON (default is CSV)
- -f, --fields
return specific fields. By default a core set of fields is returned, but additional vendor-specific fields are also available. To return non-core fields, you can reference them by name, or pass “*” to return all available fields. To return all fields for a specific vendor, pass the vendor prefix followed by “*”, for example “edi*” for all EDI fields. Pass “?*” (or any invalid vendor prefix plus “*”) to see available vendor prefixes. Pass “?” or any invalid fieldname to see all available fields.
Query security details from the securities master database and download to
file.
Examples:
Download NYSE and NASDAQ securities to file, using MICs to specify
the exchanges:
quantrocket master get –exchanges XNYS XNAS -o securities.csv
Download NYSE and NASDAQ securities to file, using IBKR exchange codes
to specify the exchanges, and include all IBKR fields:
quantrocket master get –exchanges NYSE NASDAQ -f ‘ibkr*’ -o securities.csv
Download a CSV of all ARCA ETFs and use it to create a universe called
“arca-etf”:
quantrocket master get –exchanges ARCA –sec-types ETF | quantrocket master universe “arca-etf” –infile -
Query the exchange and currency for all listings of AAPL and format for
terminal display:
quantrocket master get –symbols AAPL –fields Exchange Currency | csvlook -I
list-ibkr-exchanges
list exchanges by security type and country as found on the IBKR website
quantrocket master list-ibkr-exchanges [-h] [-r [REGION [REGION ...]]]
[-t [SEC_TYPE [SEC_TYPE ...]]]
Named Arguments
- -r, --regions
Possible choices: north_america, europe, asia, global
limit to these regions. Possible choices: [‘north_america’, ‘europe’, ‘asia’, ‘global’]
- -t, --sec-types
Possible choices: STK, ETF, FUT, CASH, IND
limit to these security types. Possible choices: [‘STK’, ‘ETF’, ‘FUT’, ‘CASH’, ‘IND’]
List exchanges by security type and country as found on the IBKR website.
Examples:
List all exchanges:
quantrocket master list-ibkr-exchanges
List stock exchanges in North America:
quantrocket master list-ibkr-exchanges –regions north_america –sec-types STK
diff-ibkr
flag security details that have changed in IBKR’s system since the time they were last collected into the securities master database
quantrocket master diff-ibkr [-h] [-u [UNIVERSE [UNIVERSE ...]]]
[-i [SID [SID ...]]] [-n INFILE]
[-f [FIELD [FIELD ...]]] [--delist-missing]
[--delist-exchanges [EXCHANGE [EXCHANGE ...]]]
[-w]
Named Arguments
- -u, --universes
limit to these universes
- -i, --sids
limit to these sids
- -n, --infile
limit to the sids in this file (specify ‘-‘ to read file from stdin)
- -f, --fields
only diff these fields (field name should start with ‘ibkr’)
- --delist-missing
auto-delist securities that are no longer available from IBKR
Default: False
- --delist-exchanges
auto-delist securities that are associated with these exchanges
- -w, --wait
run the diff synchronously and return the diff (otherwise run asynchronously and log the results, if any, to flightlog
Default: False
Flag security details that have changed in IBKR’s system since the time they
were last collected into the securities master database.
Diff can be run synchronously or asynchronously (asynchronous is the default
and is recommended if diffing more than a handful of securities).
Examples:
Asynchronously generate a diff for all securities in a universe called
“italy-stk” and log the results, if any, to flightlog:
quantrocket master diff-ibkr -u “italy-stk”
Asynchronously generate a diff for all securities in a universe called
“italy-stk”, looking only for sector or industry changes:
quantrocket master diff-ibkr -u “italy-stk” –fields ibkr_Sector ibkr_Industry
Synchronously get a diff for specific securities by sid:
quantrocket master diff-ibkr –sids FIBBG000LV0836 FIBBG000B9XRY4 –wait
Synchronously get a diff for specific securities without knowing their sids:
quantrocket master get -e NASDAQ -t STK -s AAPL FB GOOG | quantrocket master diff-ibkr –wait –infile -
Asynchronously generate a diff for all securities in a universe called
“nasdaq-sml” and auto-delist any symbols that are no longer available from IBKR
or that are now associated with the PINK exchange:
quantrocket master diff-ibkr -u “nasdaq-sml” –delist-missing –delist-exchanges PINK
delist-ibkr
mark an IBKR security as delisted
quantrocket master delist-ibkr [-h] [-i SID] [-s SYMBOL] [-e EXCHANGE]
[-c CURRENCY] [-t SEC_TYPE]
Named Arguments
- -i, --sid
the sid of the security to be delisted
- -s, --symbol
the symbol to be delisted (if sid not provided)
- -e, --exchange
the exchange of the security to be delisted (if needed to disambiguate)
- -c, --currency
the currency of the security to be delisted (if needed to disambiguate)
- -t, --sec-type
Possible choices: STK, ETF, FUT, CASH, IND
the security type of the security to be delisted (if needed to disambiguate). Possible choices: [‘STK’, ‘ETF’, ‘FUT’, ‘CASH’, ‘IND’]
Mark an IBKR security as delisted.
This does not remove any data but simply marks the security as delisted so
that data services won’t attempt to collect data for the security and so
that the security can be optionally excluded from query results.
The security can be specified by sid or a combination of other
parameters (for example, symbol + exchange). As a precaution, the request
will fail if the parameters match more than one security.
Examples:
Delist a security by sid:
quantrocket master delist-ibkr -i FIBBG1234567890
Delist a security by symbol + exchange:
quantrocket master delist-ibkr -s ABC -e NYSE
list-universes
list universes and their size
quantrocket master list-universes [-h]
List universes and their size.
Examples:
quantrocket master list-universes
universe
create a universe of securities
quantrocket master universe [-h] [-f INFILE]
[--from-universes [UNIVERSE [UNIVERSE ...]]]
[--exclude-delisted] [-a | -r]
CODE
Positional Arguments
- CODE
the code to assign to the universe (lowercase alphanumerics and hyphens only)
Named Arguments
- -f, --infile
create the universe from the sids in this file (specify ‘-‘ to read file from stdin)
- --from-universes
create the universe from these existing universes
- --exclude-delisted
exclude delisted securities and expired contracts that would otherwise be included (default is to include them)
Default: False
- -a, --append
append to universe if universe already exists
Default: False
- -r, --replace
replace universe if universe already exists
Default: False
Create a universe of securities.
Examples:
Download a CSV of Italian stocks then upload it to create a universe called
“italy-stk”:
quantrocket master get –exchanges BVME –sec-types STK -f italy.csv
quantrocket master universe “italy-stk” -f italy.csv
In one line, download a CSV of all ARCA ETFs and append to a universe called
“arca-etf”:
quantrocket master get –exchanges ARCA –sec-types ETF | quantrocket master universe “arca-etf” –append –infile -
Create a universe consisting of several existing universes:
quantrocket master universe “asx” –from-universes “asx-sml” “asx-mid” “asx-lrg”
Copy a universe but exclude delisted securities:
quantrocket master universe “hong-kong-active” –from-universes “hong-kong” –exclude-delisted
delete-universe
delete a universe
quantrocket master delete-universe [-h] code
Positional Arguments
- code
the universe code
Delete a universe.
The listings details of the member securities won’t be deleted, only their
grouping as a universe.
Examples:
Delete the universe called “italy-stk”:
quantrocket master delete-universe ‘italy-stk’
create-ibkr-combo
Create an IBKR combo (aka spread)
quantrocket master create-ibkr-combo [-h] PATH
Positional Arguments
- PATH
a JSON file containing an array of the combo legs, where each leg is an array specifying action, ratio, and sid
Create an IBKR combo (aka spread), which is a composite instrument consisting
of two or more individual instruments (legs) that are traded as a single
instrument.
Each user-defined combo is stored in the securities master database with a
SecType of “BAG”. The combo legs are stored in the ComboLegs field as a JSON
array. QuantRocket assigns a sid for the combo consisting of a prefix ‘IC’
followed by an autoincrementing digit, for example: IC1, IC2, IC3, …
If the combo already exists, its sid will be returned instead of creating a
duplicate record.
Examples:
Create a spread from a JSON file:
cat spread.json
[[“BUY”, 1, QF12345],
quantrocket master create-ibkr-combo spread.json
rollrules
upload a new rollover rules config, or return the current rollover rules
quantrocket master rollrules [-h] [FILENAME]
Positional Arguments
- FILENAME
the rollover rules YAML config file to upload (if omitted, return the current config)
Upload a new rollover rules config, or return the current rollover rules.
Examples:
Upload a new rollover config (replaces current config):
quantrocket master rollrules myrolloverrules.yml
Show current rollover config:
quantrocket master rollrules
collect-ibkr-calendar
collect upcoming trading hours from IBKR for exchanges and save to securities master database
quantrocket master collect-ibkr-calendar [-h] [-e [EXCHANGE [EXCHANGE ...]]]
Named Arguments
- -e, --exchanges
limit to these exchanges
Collect upcoming trading hours from IBKR for exchanges and save to securities
master database.
Examples:
Collect trading hours for ARCA:
quantrocket master collect-ibkr-calendar -e ARCA
calendar
check whether exchanges are open or closed
quantrocket master calendar [-h] [-t SEC_TYPE] [-i TIMEDELTA | -a TIMEDELTA]
[-o]
EXCHANGE [EXCHANGE ...]
Positional Arguments
- EXCHANGE
the exchange(s) to check
Named Arguments
- -t, --sec-type
Possible choices: STK, FUT, CASH, OPT
the security type, if needed to disambiguate for exchanges that trade multiple security types. Possible choices: [‘STK’, ‘FUT’, ‘CASH’, ‘OPT’]
- -i, --in
check whether exchanges will be open or closed at this point in the future (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -a, --ago
check whether exchanges were open or closed this long ago (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -o, --outside-rth
check extended hours calendar (default is to check regular trading hours calendar)
Default: False
Check whether exchanges are open or closed.
Examples:
Check whether NYSE is open or closed now:
quantrocket master calendar NYSE
Check whether the Tokyo Stock Exchange was open or closed 5 hours ago:
quantrocket master calendar TSEJ –ago 5h
Check whether GLOBEX will be open or closed in 30 minutes:
quantrocket master calendar GLOBEX –in 30min
isopen
assert that one or more exchanges are open and exit non-zero if closed
quantrocket master isopen [-h] [-t SEC_TYPE] [-i TIMEDELTA | -a TIMEDELTA]
[-s FREQ | -u FREQ] [-o]
EXCHANGE [EXCHANGE ...]
Positional Arguments
- EXCHANGE
the exchange(s) to check
Named Arguments
- -t, --sec-type
Possible choices: STK, FUT, CASH, OPT
the security type, if needed to disambiguate for exchanges that trade multiple security types. Possible choices: [‘STK’, ‘FUT’, ‘CASH’, ‘OPT’]
- -i, --in
assert that exchanges will be open at this point in the future (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -a, --ago
assert that exchanges were open this long ago (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -s, --since
assert that exchanges have been opened (as of –in or –ago if applicable) since at least this time (use Pandas frequency string, e.g. ‘W’ (week end), ‘M’ (month end), ‘Q’ (quarter end), ‘A’ (year end))
- -u, --until
assert that exchanges will be opened (as of –in or –ago if applicable) until at least this time (use Pandas frequency string, e.g. ‘W’ (week end), ‘M’ (month end), ‘Q’ (quarter end), ‘A’ (year end))
- -o, --outside-rth
check extended hours calendar (default is to check regular trading hours calendar)
Default: False
Assert that one or more exchanges are open and exit non-zero if closed.
Intended to be used as a conditional for running other commands.
Examples:
Place Moonshot orders if NYSE is open now:
quantrocket master isopen NYSE && quantrocket moonshot orders my-strategy | quantrocket blotter order -f -
Collect historical data for Australian stocks if the exchange was open 4 hours ago:
quantrocket master isopen ASX –ago 4h && quantrocket history collect asx-stk-1d
Log a message if the London Stock Exchange will be open in 30 minutes:
quantrocket master isopen LSE –in 30min && quantrocket flightlog log ‘the market opens soon!’
isclosed
assert that one or more exchanges are closed and exit non-zero if open
quantrocket master isclosed [-h] [-t SEC_TYPE] [-i TIMEDELTA | -a TIMEDELTA]
[-s FREQ | -u FREQ] [-o]
EXCHANGE [EXCHANGE ...]
Positional Arguments
- EXCHANGE
the exchange(s) to check
Named Arguments
- -t, --sec-type
Possible choices: STK, FUT, CASH, OPT
the security type, if needed to disambiguate for exchanges that trade multiple security types. Possible choices: [‘STK’, ‘FUT’, ‘CASH’, ‘OPT’]
- -i, --in
assert that exchanges will be closed at this point in the future (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -a, --ago
assert that exchanges were closed this long ago (use Pandas timedelta string, e.g. 2h or 30min or 1d)
- -s, --since
assert that exchanges have been closed (as of –in or –ago if applicable) since at least this time (use Pandas frequency string, e.g. ‘W’ (week end), ‘M’ (month end), ‘Q’ (quarter end), ‘A’ (year end))
- -u, --until
assert that exchanges will be closed (as of –in or –ago if applicable) until at least this time (use Pandas frequency string, e.g. ‘W’ (week end), ‘M’ (month end), ‘Q’ (quarter end), ‘A’ (year end))
- -o, --outside-rth
check extended hours calendar (default is to check regular trading hours calendar)
Default: False
Assert that one or more exchanges are closed and exit non-zero if open.
Intended to be used as a conditional for running other commands.
For –since/–until options, pass a Pandas frequency string, i.e. any string that
is a valid freq argument to pd.date_range. See:
https://pandas.pydata.org/pandas-docs/stable/user_guide/timeseries.html#offset-aliases
https://pandas.pydata.org/pandas-docs/stable/user_guide/timeseries.html#anchored-offsets
Examples:
Place Moonshot orders if the NYSE will be closed NYSE in 1 hour:
quantrocket master isclosed NYSE –in 1h && quantrocket moonshot orders my-strategy | quantrocket blotter order -f -
Collect historical data for Australian stocks if the exchange is closed now but was
open 4 hours ago:
quantrocket master isclosed ASX && quantrocket master isopen ASX –ago 4h && quantrocket history collect asx-stk-1d
Place Moonshot orders if the NYSE has been closed since month end:
quantrocket master isclosed NYSE –since M && quantrocket moonshot orders monthly-rebalancing-strategy | quantrocket blotter order -f -
Place Moonshot orders if the NYSE will be closed in 1 hour and remain closed through quarter end:
quantrocket master isclosed NYSE –in 1H –until Q && quantrocket moonshot orders end-of-quarter-strategy | quantrocket blotter order -f -
ticksize
round prices in a CSV to valid tick sizes
quantrocket master ticksize [-h] -f INFILE -r FIELD [FIELD ...] [-d DIRECTION]
[-a] [-o OUTFILE]
Named Arguments
- -f, --infile
CSV file with prices to be rounded (specify ‘-‘ to read file from stdin)
- -r, --round
columns to be rounded
- -d, --how
Possible choices: up, down, nearest
which direction to round to. Possible choices: up, down, nearest (default is ‘nearest’)
- -a, --append-ticksize
append a column of tick sizes for each field to be rounded
Default: False
- -o, --outfile
filename to write the data to (default is stdout)
Round prices in a CSV file to valid tick sizes.
CSV should contain columns Sid, Exchange, and the columns to be rounded
(e.g. LmtPrice). Additional columns will be ignored and returned unchanged.
Examples:
Round the LmtPrice column in a CSV of orders and return a new CSV:
quantrocket master ticksize -f orders.csv –round LmtPrice -o rounded_orders.csv
Round the StopPrice column in a CSV of orders and append the tick size as a
new column (called StopPriceTickSize):
quantrocket master ticksize -f orders.csv -r StopPrice –append-ticksize -o rounded_orders.csv
Round the LmtPrice column in a CSV of Moonshot orders then place the orders:
quantrocket moonshot orders umd-japan | quantrocket master ticksize -f - -r LmtPrice | quantrocket blotter order -f -