PortfolioAccount (Prime/Demo Account)

About 17 min

from tigeropen.common.util.order_utils import market_order_by_amount--- title: Object Details

PortfolioAccount (Prime/Demo Account)

tigeropen.trade.domain.prime_account.PortfolioAccount sourceopen in new window

Description
Account Equity object, for synthetic/demo accounts. Contains the account's total assets, profit and loss, market value of positions, cash, available funds, margin, leverage and other related information

Object Properties

property nametypedescription
accountstrcorresponding account id
update_timestampintUpdate time, 13-digit timestamp in milliseconds
segmentstigeropen.trade.domain.prime_account.SegmentAccount information by trade type. The content is a dict with two keys, 'S' for securities, 'C' for futures, and the value is Segment object.

Segment (Prime/Demo Account)

tigeropen.trade.domain.prime_account.Segment sourceopen in new window

Description Divide assets according to stock/futures trading varieties, and each part is a segment.

Object Properties

property nametypedescription
currencystrCurrency, such as USD, HKD
capabilitystrAccount Type, Margin: RegTMargin, Cash: Cash
categorystrSecurities Category C: (Commodities Futures), S: (Securities Stocks),F: (Funds)
cash_balancefloatThe cash that can be traded, plus the cash that has been locked (such as stocks that have been purchased but not yet traded, and some other situations will also have locked cash)
cash_available_for_tradefloatAmount of cash that can be traded in the current account
cash_available_for_withdrawalfloatAmount of cash that can be withdrawn in the current account
gross_position_valuefloatTotal value of securities: long stock value + short stock value + long option value + short option value. The above items are calculated as absolute values
equity_with_loanfloatEquity with loan value (including loan value assets). Securities Segment: cash value + stock value, futures Segment: cash value - maintenance margin
net_liquidationfloatNet Liquidation Value
init_marginfloatinitial margin requirement
maintain_marginfloatMaintenance margin requirement
overnight_marginfloatOvernight margin requirement
unrealized_plfloatfloating profit and loss
realized_plfloatRealized P&L
excess_liquidationfloatExcess liquidity, used to represent intraday risk value. Calculation method for securities segment: equity_with_loan - maintenance_margin_requirement. Calculation method for futures segment: net_liquidation - maintenance_margin_requirement
overnight_liquidationfloatOvernight risk control value, when it is less than 0, account positions will be forced to liquidate, you need to pay attention to the risks
buying_powerfloatbuying power. Estimate how many more dollars you can buy in stock assets. The margin account has a maximum of four times the purchasing power of the funds (funds that are not used for margin) during the day. Up to twice the purchasing power overnight
leveragefloatThe leverage multiplier currently used. When it is less than 1, it indicates that no leverage is used. When it is greater than 1, it indicates that leverage is used.
_currency_assetsdictAccount asset information differentiated by transaction currency, is a dict with currency as key, and value as CurrencyAsset object
consolidatedSegTypesstringconsolidated Segment. The following are the fields of consolidated Segment:cash_available_for_trade、init_margin、maintain_margin、overnight_margin、excess_liquidation、overnight_liquidation、buying_power、locked_funds、leverage
uncollectedfloatIn transit funds
locked_fundsfloatLocked funds

CurrencyAsset (Prime/demo account)

tigeropen.trade.domain.prime_account.CurrencyAsset sourceopen in new window

Instruction
Assets by currency.

Object Properties

member nametypedescription
currencystrCurrent currency, commonly used currencies include: USD-US dollar, HKD-Hong Kong dollar, SGD-Singapore dollar, CNH-RMB
cash_balancefloatCash that can be traded, plus the cash that has been locked (such as stocks that have been purchased but not yet traded, and some other situations will also have locked cash)
cash_available_for_tradefloatThe amount of cash that can be traded in the current account
gross_position_valuefloatgross value
stock_market_valuefloatThe market value of the stock, when the category is C (futures type), there will be no stock market value
futures_market_valuefloatThe market value of futures, when the category is S (stock type), there will be no futures market value
option_market_valuefloatMarket value of the option
unrealized_plfloatUnrealizd profit and loss of the account
realized_plfloatThe realized profit and loss in the account

Account Aggregate Assets (Global Account)

tigeropen.trade.domain.account.Account sourceopen in new window

Description The account object tracks information about the trading account. The values are updated as the algorithm runs and its keys remain unchanged. If connected to a broker, one can update these values with the trading account values as reported by the broker. Asset summary information of each trading product in the account.

Object Properties

Descriptions starting with "∆" indicate that they are only applicable to the Securities Segment.

property nametypedescription
accrued_cashfloatAccumulated interest payable for the current month, updated daily
accrued_dividendfloatTotal value of all executed but not yet paid dividends
available_fundsfloatFunds Available for Trading:
Calculated as equity_with_loan - initial_margin_requirement
∆ buying_powerfloatEstimated amount of USD-denominated stock assets currently purchasable
Intraday: Up to 4 times the available funds
Overnight: Up to 2 times the available funds
cashfloatCash
currencystrCurrency
cushionfloatRemaining liquidity as a percentage of total assets: Calculated as excess_liquidity / net_liquidation
∆ day_trades_remainingintRemaining day trades for the day: -1 indicates no limit on the number of day trades for the day
equity_with_loanfloatEquity with Loan Value (Including Loan Value Assets)
Securities Segment: Cash value + Stock value
Futures Segment: Cash value - Maintenance margin
excess_liquidityfloatRemaining Liquidity
Securities Segment: equity_with_loan - maintenance_margin_requirement
Futures Segment: net_liquidation - maintenance_margin_requirement
∆ gross_position_valuefloatTotal Value of Securities: long stocks + short stocks + long options + short options
Each of the above items is calculated using absolute values
initial_margin_requirementfloatInitial margin
maintenance_margin_requirementfloatMaintenance margin
realized_pnlfloatRealized Profit and Loss (P&L) for the day
unrealized_pnlfloatUnrealized Profit and Loss (P&L)
net_liquidationfloatTotal assets (Net liquidation value):
Securities Segment: Cash value + Stock value + Stock options value
Futures Segment: Cash value + Mark-to-market P&L
∆ regt_equityfloat(Securities Segment only)
Equity with loan calculated based on the Regulation T Act (including loan value of securities)
∆ regt_marginfloat(Securities Segment only)
Initial margin requirements calculated based on the Regulation T Act
∆ smafloat(Securities Segment only) Overnight risk control value, which checks the overnight risk of the account's positions approximately 10 minutes before the market closes each trading day. The overnight risk control value must be greater than 0; otherwise, some positions will be forcibly closed before the market closes. If the overnight risk control value falls below 0 during the trading day but is still more than 10 minutes before market close, the account will not trigger forced liquidation
timestampintTimestamp

SecuritySegment Equity Assets (Global Account)

tigeropen.trade.domain.account.SecuritySegment sourceopen in new window

Instruction
Stock asset information.

Object Properties

property nametypedescription
accrued_cashfloatThe accumulated interest payable in the current month, updated daily.
accrued_dividendfloatCumulative dividends. Refers to the cumulative value of all dividends that have been executed but not paid
available_fundsfloatAvailable funds (available for trading). Calculated as equity_with_loan - initial_margin_requirement
cashfloatCash
equity_with_loanfloatEquity with loan value (asset with loan value). Calculation method: cash value + stock value
excess_liquidityfloatExcess liquidity. Calculation method: equity_with_loan - maintenance_margin_requirement
gross_position_valuefloatTotal value of securities: long stock value + short stock value + long option value + short option value. The above items are calculated as absolute values.
initial_margin_requirementfloatInitial Margin
maintenance_margin_requirementfloatMaintenance margin
leveragefloatFor securities only Segment gross_position_value / net_liquidation
net_liquidationfloatTotal assets (net liquidation value). Calculation method: cash value + stock value + stock option value
regt_equityfloatOnly for the securities segment, that is, the equity with loan (including the loan equity value) calculated according to the Regulation T Act
regt_marginfloatFor security segments only, i.e. initial margin requirements calculated under Regulation T
smafloatFor security segments only. Overnight risk control value, the overnight risk of account positions is checked about 10 minutes before the close of each trading day. The overnight risk control value needs to be greater than 0, otherwise some positions in the account will be forced to close before the market closes. If the overnight risk control value is lower than 0 during the trading day, and the time is not 10 minutes before the closing time, the account will not be liquidated.
timestampintUpdate time

CommoditySegment Futures Assets (Global Account)

tigeropen.trade.domain.account.CommoditySegment sourceopen in new window

Instruction
Futures asset information.

Object Properties

property nametypedescription
accrued_cashfloatThe accumulated interest payable in the current month, updated daily.
accrued_dividendfloatCumulative dividends. Refers to the cumulative value of all dividends that have been executed but not paid
available_fundsfloatAvailable funds (available for trading). Calculated as equity_with_loan - initial_margin_requirement
cashfloatCash
equity_with_loanfloatEquity with loan value (asset with loan value) calculation method: cash value - maintenance margin
excess_liquidityfloatExcess liquidity. Calculation method: net_liquidation - maintenance_margin_requirement
initial_margin_requirementfloatInitial Margin
maintenance_margin_requirementfloatMaintenance Margin
net_liquidationfloatTotal assets (net liquidation value). Calculation method: cash value + mark-to-market profit and loss
timestampintUpdate time

MarketValue sub-currency assets (Global account)

tigeropen.trade.domain.account.MarketValue sourceopen in new window

Instruction
Asset information by currency.

Object Properties

property nametypedescription
currencystrcurrency unit
net_liquidationfloatTotal Assets (Net Liquidation Value)
cash_balancefloatcash
stock_market_valuefloatstock market value
option_market_valuefloatOption Market Value
warrant_valuefloatWarrant Market Value
futures_pnlfloatMark to Market
unrealized_pnlfloatUnrealized PNL
realized_pnlfloatRealized P&L
exchange_ratefloatExchange rate to account's primary currency
net_dividendfloatNet dividends payable and dividends receivable
timestampintUpdate time

PortfolioAccount (Global Account)

tigeropen.trade.domain.account.PortfolioAccount sourceopen in new window

Description
Account Equity object. Contains the account's total assets, profit and loss, market value of positions, cash, available funds, margin, leverage and other related information

Object Properties

property nametypedescription
accountstrcorresponding account id
summarytigeropen.trade.domain.account.AccountAccount summary information, statistics on segments
segmentsdictAccount information by trading type. There are two keys, 'S' means [securities](/en/python/appendix1/object.md#securitysegment-object-global account), 'C' means [futures](/en/python/appendix1/object. html#commoditysegment-object-global-account).
market_valuesdictAccount information by currency. The key: 'USD' means US dollar, 'HKD' means Hong Kong dollar; value is a [MarketValue object](/en/python/appendix1/object.md#marketvalue-object-global account)

Position position

tigeropen.trade.domain.position.Position sourceopen in new window

instruction
Account holding information, including details such as the contract asset, number of positions, cost, and profit & loss.

Object Properties

property nametypedescription
accountstrThe corresponding account ID
contracttigeropen.trade.domain.contract.ContractContract object
quantityintContract quantity (deprecated)
average_costfloatAverage cost with commission
average_cost_by_averagefloat
average_cost_of_carryfloatAccumulated position cost (A-share calculation method)
market_pricefloatLatest market price
market_valuefloatMarket Cap
realized_pnlfloatRealized profit and loss in FIFO rule
realized_pnl_by_averagefloat
unrealized_pnlfloatUnrealized profit and loss
unrealized_pnl_by_averagefloat
position_scaleintContract quantity scale (deprecated) For example, the position value is 11123, the positionScale is 2, and the actual number of positions is 11123*10^(-2)=111.23
unrealized_pnl_percent
unrealized_pnl_percent_by_average
mm_value
mm_percent
position_qtyfloatPosition quantity
salable_qtyfloatSaleable quantity
today_pnlfloatToday's profit and loss
today_pnl_percentfloatToday's profit and loss percentage
yesterday_pnlfloatYesterday's profit and loss, Fund only
last_close_pricefloatThe closing price on the last trading day (pre-adjusted for stock rights)
unrealized_pnl_by_cost_of_carryfloatUnrealized profit and loss by cost of carry
unrealized_pnl_percent_by_cost_of_carryfloatUnrealized profit and loss percentage by cost of carry
is_level0_pricebooleanis lv0(delay) quote

Order object

tigeropen.trade.domain.order.Order sourceopen in new window

Instruction
Order object. Querying an order will return this object, and the parameters of placing an order to change an order also need to use this object.

Object Properties

property nametypedescription
accountstrThe account to which the order belongs
idlongGlobal order ID
order_idintAccount auto-increment order number (deprecated)
parent_idlongParent order ID, currently only used for attached orders in the TigerTrade App
order_timeintOrder time, a 13-digit timestamp in milliseconds
trade_timeintOrder status update time.
Completed orders: completion time
Canceled orders: Successful cancellation time
The timestamp is in milliseconds with 13 digits
update_timeintOrder update time given in milliseconds with 13 digits
expire_timeintGTD (Good Till Date) order expiration time, in milliseconds with a 13-digit timestamp
reasonstrUpon failure, the description of the reason for the failure will be returned
actionstrTrade direction: 'BUY' / 'SELL'
quantityintOrder quantity
quantity_scaleintThe offset of the order quantity, defaulting to 0. For fractional share orders, the combination of quantity and quantity_scale represents the actual order quantity. For example, if quantity=111 and quantity_scale=2, the real quantity would be 111 * 10^(-2) = 1.11
total_cash_amountfloatThe total order amount, which is None when the order is placed by number of shares
filled_cash_amountfloatThe total amount executed, which is None when the order is placed by number of shares
refund_cash_amountfloatThe returned amount, which equals the total order amount minus the executed amount. It is None when the order is placed by number of shares or if the order is not finalized
filledintExecuted Quantity
avg_fill_pricefloatAverage Execution Price Excluding Commission
commissionfloatIncludes commission, stamp duty, securities regulatory fees, and other related charges
gstfloatGoods and Service Tax
realized_pnlfloatRealized profit and loss
trail_stop_pricefloatTrailing stop price
limit_pricefloatLimit order price
aux_pricefloatStop-loss order: price at which the stop-loss order is triggered
Trailing stop order: price difference being tracked.
trailing_percentfloatTrailing stop order - Percentage, with a value range from 0 to 100
percent_offsetfloat<This field is not used>
order_typestrOrder type:
'MKT': Market Order'
LMT': Limit Order
'STP': Stop Order
'STP_LMT': Stop Limit Order
'TRAIL': Trailing Stop Order
time_in_forcestrValidity:
'DAY': Valid for the day
'GTC': Valid untill cancelled
'GTD': Valid until a specified date (requires expire_time)
outside_rthboolSupports pre-market and after-market trading, exclusive to US stocks
trading_session_typestrNight trading
contractContracttigeropen.trade.domain.contract.Contract Contract Object
statusOrderStatustigeropen.common.consts.OrderStatus OrderStatus Enum
remainingintUnfilled quantity
sub_idslist[int]List of sub-order IDs for attached orders (this field will only have a value when attaching an order)
adjust_limitfloatPrice adjustment range (default 0 means no adjustment, positive number means adjust upward, negative number means adjust downward). The price will be automatically adjusted to a valid price. For example, 0.001 means adjusting upward with a range not exceeding 0.1%; -0.001 means adjusting downward with a range not exceeding 0.1%. Default 0 means no adjustment
user_markstrUser-defined remarks
latest_pricefloatMarket price at the time of placing the order
chargestigeropen.trade.domain.order.ChargeOrder commission and other fee details (only available for individual order queries via TradeClient.get_order). See below for specifics

tigeropen.trade.domain.order.Charge

property nametypedescription
categorystrFee type (TIGER/THIRD_PARTY)
category_descstrFee category description: Tiger Charge; Third Parties
totalfloatCurrent category fee total
detailstigeropen.trade.domain.order.ChargeDetailFee details

tigeropen.trade.domain.order.ChargeDetail

property nametypedescription
typestrFee type: SETTLEMENT_FEE/STAMP_DUTY/TRANSACTION_LEVY/EXCHANGE_FEE/FRC_TRANSACTION_LEVY
type_descstrFee type description: Settlement Fee; Stamp Duty; Transaction Levy; Exchange Fee; AFRC Transaction Levy
original_amountfloatFee amount
after_discount_amountfloatAfter discount fee

Build method:

Generate order objects locally via tigeropen.common.util.order_utilsopen in new window in the SDK: order_utils only provides commonly used parameters. If additional parameters are required, after generating the order object, modify its properties.

from tigeropen.common.util.contract_utils import stock_contract
from tigeropen.common.util.order_utils import (market_order,  # market order
                                               limit_order,  # limit order
                                               stop_order,  # stop order
                                               stop_limit_order,  # stop limit order
                                               trail_order,  # trailing stop order
                                               order_leg)  # additional order

contract = stock_contract('AAPL', currency='USD')
order = limit_order('your account', contract, 'BUY', 100, 150.5)
order.time_in_force = 'GTC'  # Set order properties

# Next steps...

market_order Market order

market_order(account, contract, action, quantity)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
quantityintThe quantity of the order, which must be an integer greater than 0

return

Order object

market_order_by_amount Market order

market_order_by_amount(account, contract, action, amount)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
amountintThe amount of cash for the order, which must be an integer greater than 0

return

Order object

limit_order Limit order

limit_order(account, contract, action, quantity, limit_price)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
quantityintThe quantity of the order, which must be an integer greater than 0
limit_pricefloatThe price of the limit price, must be greater than 0

return

Order object

stop_order Stop order

stop_order(account, contract, action, quantity, aux_price)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
quantityintThe quantity of the order, which must be an integer greater than 0
aux_pricefloatPrice that triggers the stop loss order, must be greater than 0

return

Order object

stop_limit_order Stop limit order

stop_limit_order(account, contract, action, quantity, limit_price, aux_price)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
quantityintThe quantity of the order, which must be an integer greater than 0
limit_pricefloatThe price of the limit price, must be greater than 0
aux_pricefloatPrice that triggers the stop loss order, must be greater than 0

return

Order object

trail_order Trailing stop order

trail_order(account, contract, action, quantity, trailing_percent=None, aux_price=None)

parameter

parameter nametypedescription
accountstrOrder account, you can use an integrated account, a global account or a demo account
contracttigeropen.trade.domain.contract.Contractcontract object to trade
actionstrtrading direction, 'BUY' / 'SELL'
quantityintThe quantity of the order, which must be an integer greater than 0
trailing_percentfloatTrailing stop order - percentage, the value range is 0-100, aux_price and trailing_percent are mutually exclusive
aux_pricefloatSpread, mutually exclusive with trailing_percent

return

Order object

order_leg Additional order

order_leg(leg_type, price, time_in_force='DAY', outside_rth=None):

parameter

parameter nametypedescription
leg_typestrAdditional order type. 'PROFIT' Take Profit order type, 'LOSS' Stop Loss order type
pricefloatAdditional order price.
time_in_forcestrAdditional order validity period. 'DAY' (good for the day) and 'GTC' (good-Til-Canceled).
outside_rthboolWhether additional orders allow pre-market and after-hours trading (exclusive to US stocks). True allows, False does not allow.

return

OrderLeg object tigeropen.trade.domain.order.OrderLeg

auction_limit_order Auction limit order

auction_limit_order(account, contract, action, quantity, limit_price, time_in_force)parameter

parameter nametypedescription
accountstrPlace order account
contracttigeropen.trade.domain.contract.ContractContract objectopen in new window
actionstrTrade Direction,’Buy‘/'Sell'
quantityintOrder quantities, must be an integer greater than 0
limit_pricefloatLimit price, must greater than 0
time_in_forcestrAdditional order validity period. 'DAY' (good for the day) and 'GTC' (good-Til-Canceled).

return

Order

Transaction transaction record

tigeropen.trade.domain.order.Transaction

Explanation Note Transaction records of orders

parameter

parameter nametypedescription
accountstraccount
order_idintorder id
contractContractcontract object
idinttransaction record id
actionstrOrder direction
filled_quantityinttransacted quantity
filled_pricefloattransacted price
filled_amountfloattransacted amount
transacted_atstrtransacted time

OrderLeg Additional order

tigeropen.trade.domain.order.OrderLeg

Explanation

Additional orders that are carried along with the main order

parameter

parameter nametypedescription
leg_typestrAdditional order type: PROFIT - Take Profit order type, LOSS - Stop Loss order type; LMT / STP / STP_LMT are only supported for OCA (One-Cancels-All) orders
pricefloatTrigger price for the additional order
time_in_forcestrValidity period
'DAY': Valid for the current day
'GTC': Good till cancel
'GTD': Good till date
outside_rthboolWhether pre-market and after-hours trading are allowed (US stocks only)
limit_pricefloatLimit order price
trailing_percentfloatTrailing stop loss order-stop loss percentage, when trailing stop loss order, one of the stop loss percentage (stopLossTrailingPercent) and stop loss amount (stopLossTrailingAmount) must be filled in, if both are filled, the stop loss percentage will be used as the parameter
trailing_amountfloatTrailing stop loss order-stop loss amount, when trailing stop loss order, one of stop loss percentage (stopLossTrailingPercent) and stop loss amount (stopLossTrailingAmount) must be filled in, if both are filled, the stop loss percentage will be used as parameter
quantityintOrder quantity

AlgoParams Algo order parameters

tigeropen.trade.domain.order.AlgoParams

Explanation

Algo order(VWAP/TWAP)parameters

parameter

parameter nametypedescription
start_timestr or intEffective start time (time string or timestamp, dedicated to TWAP and VWAP), such as '2020-11-19 23:00:00' or 1640159945678
end_timestr or intExpiration time (time string or timestamp TWAP and VWAP specific)
no_take_liqboolWhether to reduce the number of transactions as much as possible (only for VWAP orders)
allow_past_end_timeboolWhether to allow the transaction to continue after the expiration time (TWAP and VWAP only)
participation_ratefloatParticipation rate (for VWAP only, 0.01-0.5)

Contract object

tigeropen.trade.domain.contract.Contract sourceopen in new window

Description
A contract refers to the transaction object or subject matter (such as a stock or an option), and the contract is uniformly formulated by the exchange. For example, buying stocks of Tiger Securities can be uniquely identified by the letter code TIGR and market information (ie market='US', the US market). Similarly, when purchasing options or futures products, other identification fields may be required. Through the contract information, we can uniquely determine a target when placing an order or obtaining market quotations. In the Open API Python SDK, contract information is stored through the tigeropen.trade.domain.contract.Contract object. The Contract object can be passed into the tool function that constructs the Order order object to create the Order object for placing an order

Common contracts include stock contracts, options contracts, futures contracts, etc. Most contracts include the following elements:

  • The subject code (symbol), generally the contract codes such as US stocks and British stocks are English letters, and the contract codes such as Hong Kong stocks and A shares are numbers. For example, the symbol of Tiger Securities is TIGR.
  • Contract type (security type), common contract types include: STK (stock), OPT (option), FUT (futures), CASH (foreign exchange). For example, the contract type of Tiger Securities stock is STK.
  • Currency type (currency), common currencies include USD (US dollar), HKD (Hong Kong dollar).
  • Exchange, STK type contracts generally do not use the exchange field, orders will be automatically routed, and futures contracts use the exchange field.

The vast majority of stocks, CFDs, indices or forex pairs can be uniquely identified by these four properties. Due to their nature, more complex contracts such as options and futures require some additional information. Here are a few common types of contracts and what they consist of:

stock

from tigeropen.common.util.contract_utils import stock_contract

contract = stock_contract(symbol='TIGR', currency='USD')
contract1 = stock_contract(symbol='00700', currency='HKD')

options

from tigeropen.common.util.contract_utils import option_contract

contract = option_contract(identifier='AAPL 190118P00160000')

futures

from tigeropen.common.util.contract_utils import future_contract

contract = future_contract(symbol='CL', currency='USD', expiry='20190328', multiplier=1.0, exchange='SGX')

Hongkong Warrant

from tigeropen.common.util.contract_utils import war_contract_by_symbol

contract = war_contract_by_symbol('01810', '20221116', 14.52, 'CALL', local_symbol='14759', multiplier=2000,
                                  currency='HKD')

Hongkong Callable Bull/Bear Contracts

from tigeropen.common.util.contract_utils import iopt_contract_by_symbol

contract = iopt_contract_by_symbol('02318', '20200420', 87.4, 'CALL', local_symbol='63379', currency='HKD')

See below for specific fields and construction methods

Parameter

parameter nametypedescription
contract_idintcontract id
symbolstrContract code
currencyCurrencyCurrency type
sec_typeSecurityTypeSecurities Type
exchangestrExchange
origin_symbolstr
local_symbolstr
expirystrExpiration date (for options/futures)
strikefloatStrike Price (for options)
put_callstrOption direction, bullish bearish
multiplierfloatNumber per lot
namestrContract name
short_marginfloatshort margin ratio(deprecated, use short_initial_margin instead
short_initial_marginfloatshort initial margin ratio
short_maintenance_marginfloatshort maintenance margin ratio
short_fee_ratefloatShort rate
shortableintShort pool remaining
shortable_count
long_initial_marginfloatLong initial margin
long_maintenance_marginfloatLong Maintenance Margin
contract_monthstrContract month, such as 202201, means January 2022
identifierstrUnique identifier, the stock identifier is the same as the symbol, the option is a 21-digit identifier, such as: 'AAPL 220729C00150000', the futures identifier
primary_exchangestrStock Listing Exchange
marketstrMarket
min_tickfloatMinimum tick unit
tickSizesstrExclusive to stocks, the minimum quotation unit price interval, that is, when the pending order price is between the begin and end intervals, it must meet the tickSize requirement, begin: the left interval of the price, end: the right interval of the price, type: the interval type OPEN/OPEN_CLOSED/CLOSED/CLOSED_OPEN( open range/left open right close/closed range/left close right open), tickSize: minimum price unit, example:[{"begin":"0","end":"1","tickSize":1.0E-4,"type":"CLOSED"},{"begin":"1","end":"Infinity","tickSize":0.01,"type":"OPEN"}]
trading_classstrThe trading class name of the contract
statusstrStatus
marginable
tradeboolFutures are exclusive, whether they can be traded
close_only
continuousboolExclusive to futures, whether it is a continuous contract
last_trading_datestrExclusive to futures, the last trading day, such as '20211220', means December 20, 2021
first_notice_datestrExclusively for futures, on the first notice day, long positions cannot be opened after the first notice day. Existing long positions will be forced to close before the first notice day (usually the first three trading days). , such as '20211222', which means December 22, 2021
last_bidding_close_timeintFutures exclusive, bid closing timestamp
is_etfboolis ETF
etf_leverageintETF leverage
discounted_day_initial_marginfloatFutures only, Intraday initial margin discount
discounted_day_maintenance_marginfloatFutures only, Intraday maintenance margin discount
discounted_time_zone_codefloatFutures only, Intraday margin discount period time zone
discounted_start_atfloatFutures only, Intraday margin discount start time
discounted_end_atfloatFutures only, Intraday margin discount end time
categories
lot_size

::: Warning CAUTION Only some properties will be displayed when printing. use Contract.to_str() to display all properties. :::

Use interface Contract parameter use this function to get:

get contract information get_contract/get_contracts

parameter:

parameterrequirementdescription
symbolYesContract Exp: 00700/AAPL
sec_typeNoContract type Exp: SecurityType.STK/SecurityType.OPT
currencyNoCurrency Exp: Currency.USD/Currency.HKD
exchangeNoExchange Exp: SMART/SEHK
expiryNoExpiration Date Must be passed when the trading type is an option yyyyMMdd
strikeNoStrike price Must be passed when the transaction type is an option
put_callNoCALL/PUT Must be passed when the trading type is an option

return

get_contract return Contract parameter; get_contracts return Contract List of objects. Object properties see description above

Example

from tigeropen.trade.trade_client import TradeClient
from tigeropen.tiger_open_config import get_client_config

client_config = get_client_config(private_key_path='private key path', tiger_id='your tiger id', account='your account',
                                  secret_key='institutional trader private key')
trade_client = TradeClient(client_config)

# Get stock contract
contract = trade_client.get_contract('FB', sec_type=SecurityType.STK)
contracts = trade_client.get_contracts(['AAPL', 'TSLA'], sec_type=SecurityType.STK)

# Get future contract
fut_contract = trade_client.get_contract('CL', sec_type=SecurityType.FUT)

# Get option contract
opt_contract = trade_client.get_contract('SPY', sec_type=SecurityType.OPT, expiry='20231215', strike=435.0,
                                         put_call='CALL')

MarketStatus Market status

tigeropen.quote.domain.market_status.MarketStatus

Explanation

Market trading status

parameter

parametertypedescription
marketstrMarket(US:US Stock,CN:Shanghai and Shenzhen,HK:Hongkong)
statusstrMarket status description(Market not open,Trading,Market closed etc.)
open_timedatetime.datetimeLast opening time
trading_statusstrMarket trading status/ Market not open NOT_YET_OPEN; Pre-market hour PRE_HOUR_TRADING; Trading TRADING; Middle breaking time MIDDLE_CLOSE; Post trading hour POST_HOUR_TRADING; Market closed CLOSING; Early close EARLY_CLOSED; Market closed MARKET_CLOSED;

OptionFilter Option Filter

tigeropen.quote.domain.filter.OptionFilter

Explanation

Option filter parameter

parameter

parametertyperequirementdescription
implied_volatility_minfloatNominimum Implied volatility reflects the market's expected future stock price fluctuations. The higher the implied volatility, the more severe the expected stock price fluctuations
implied_volatility_maxfloatNomaximum Implied volatility reflects the market's expected future stock price fluctuations. The higher the implied volatility, the more severe the expected stock price fluctuations
open_interest_minintNominimum Open interest: the number of outstanding contracts in the market participants at the end of each trading day. Reflects the depth and liquidity of the market
open_interest_maxintNomaximum Open interest: the number of outstanding contracts in the market participants at the end of each trading day. Reflects the depth and liquidity of the market
delta_minfloatNominimum delta: Reflects the impact of stock price changes on option price changes. For every 1 dollar change in stock price, the option price changes approximately, . between -1.0 ~ 1.0
delta_maxfloatNomaximum delta: Reflects the impact of stock price changes on option price changes. For every 1 dollar change in stock price, the option price changes approximately, . between -1.0 ~ 1.0
gamma_minfloatNominimum gamma: Reflects the impact of stock price changes on delta. Every time the stock price changes by 1 dollar, delta changes gamma
gamma_maxfloatNomaximum gamma: Reflects the impact of stock price changes on delta. Every time the stock price changes by 1 dollar, delta changes gamma
theta_minfloatNominimum theta: Reflects the impact of time changes on option price changes. Every time the time is reduced by one day, the option price changes by theta
theta_maxfloatNomaximum theta: Reflects the impact of time changes on option price changes. Every time the time is reduced by one day, the option price changes by theta
vega_minfloatNominimum vega: Reflects the impact of volatility on option price changes. For every 1% change in volatility, the option price changes approximately vega
vega_maxfloatNomaximum vega: Reflects the impact of volatility on option price changes. For every 1% change in volatility, the option price changes approximately vega
rho_minfloatNominimum rho: Reflects the impact of the risk-free interest rate on the option price change. For every 1% change in the risk-free interest rate, the option price changes approximately rho
rho_maxfloatNomaximum rho: Reflects the impact of the risk-free interest rate on the option price change. For every 1% change in the risk-free interest rate, the option price changes approximately rho
in_the_moneyboolNoIn the money
Last update: