获取合约

大约 9 分钟

合约介绍

合约是指交易的买卖对象或者标的物(比如一只股票或一只期权),合约是由交易所统一制定的。比如购买老虎证券的股票,可以通过TIGR这个字母代号和市场信息(即market=’US‘,美国市场)来唯一标识。类似的,在购买期权或者期货产品时,可能会需要用到其他一些标识字段。

通过合约信息,我们在下单或者获取行情时就可以唯一的确定一个标的物。

常见的合约包括股票合约,期权合约,期货合约等。

大部分合约包括如下几个要素:

  • 标的代码(symbol),一般美股、英股等合约代码都是英文字母,港股、A股等合约代码是数字,比如老虎证券的symbol是TIGR。
  • 合约类型(security type),常见合约类型包括:STK(股票),OPT(期权),FUT(期货),CASH(外汇),比如老虎证券股票的合约类型是STK。
  • 货币类型(currency),常见货币包括 USD(美元),HKD(港币)。
  • 交易所(exchange),STK类型的合约一般不会用到交易所字段,订单会自动路由,期货合约都用到交易所字段。

绝大多数股票,差价合约,指数或外汇对可以通过这四个属性来唯一确定。

由于其性质,更复杂的合约(如期权和期货)需要一些额外的信息。

以下是几种常见类型合约,以及其由哪些要素构成。

股票

ContractItem contract = new ContractItem();
contract.setSymbol("TIGR");
contract.setSecType("STK");
contract.setCurrency("USD"); //非必填,下单时默认为USD
contract.setMarket("US"); //非必填,合约市场,包括US(美国市场),HK(香港市场),CN(国内市场)等。下单时默认为US

期权

老虎API的期权合约支持两种方式:

  • 一种是四要素方式,即symbol(股票代码),expiry(期权过期日),strike(期权行权价格),right(期权方向)。

  • 另一种是标准OCC期权合约格式,长度固定为21位。包含四部分:

    • 相关的股票或ETP的代码,比如(AAPL),固定占六位字符,不足位数由空格填充
    • 期权到期日,6位数字,格式为:yymmdd
    • 期权类型,取值为 P 或者 C, 表示 put 或 call
    • 期权行权价格,取值为 价格 x 1000, 固定占8位数字,前面不足的位数由0填充

    期权标识符

ContractItem contract = new ContractItem();
contract.setSymbol("AAPL");
contract.setSecType("OPT");
contract.setCurrency("USD");
contract.setExpiry("20180821");
contract.setStrike(30D);
contract.setRight("CALL");
contract.setMultiplier(100.0D);
contract.setMarket("US"); //非必填

期货

ContractItem contract = new ContractItem();
contract.setSymbol("CL1901");
contract.setSecType("FUT");
contract.setExchange("SGX");
contract.setCurrency("USD");
contract.setExpiry("20190328");
contract.setMultiplier(1.0D);

获取单个合约信息

对应的请求类:ContractRequest

说明

获取交易需要的合约信息。 需要注意环球账户、综合账户返回ContractItem字段值数目会不同,建议获取合约和下单使用相同的账户。

输入参数

com.tigerbrokers.stock.openapi.client.https.request.contract.ContractRequest

参数类型是否必填描述
accountstringYes用户授权账户:572386
symbolstringYes股票代码 如:00700 / AAPL
sec_typestringYesSTK/OPT/FUT
currencystringNoUSD/HKD/CNH
expirystringNo到期日 交易品种是期权时必传 yyyyMMdd
strikedoubleNo行权价 交易品种是期权时必传
rightstringNoCALL/PUT 交易品种是期权时必传
exchangestringNo交易所 (美股 SMART 港股 SEHK 沪港通 SEHKNTL 深港通 SEHKSZSE)
secret_keystringNo机构用户专用,交易员密钥

返回

com.tigerbrokers.stock.openapi.client.https.response.contract.ContractResponse

其中数据项字段如下 com.tigerbrokers.stock.openapi.client.https.domain.contract.item.ContractItem

名称示例说明
identifierCL2109/AAPL唯一标识,股票identifier和symbol相同,期权为21位标识符,如:'AAPL 220729C00150000',期货identifier
symbolLRN股票代码,期权合约的symbol为对应标的物代码
secTypeSTKSTK 股票/OPT 期权/FUT 期货/WAR 窝轮/IOPT 牛熊证等,默认 STK
nameK12 INC股票名称
localSymbol1033环球账户专有,港股用于识别窝轮和牛熊证
currencyUSDUSD/HKD/CNH
exchangeNYSE股票交易所
primaryExchangeNYSE股票上市交易所
marketUS市场 /US/HK/CN
expiry20171117期权和期货专有,期权或期货过期日
contractMonth201804期货专有,合约交割月份
rightPUT期权专有,期权方向,CALL 或者 PUT
strike24.0期权专有,期权的行权价格
multiplier0.0期权和期货专有,每手数量
minTick0.001最小报价单位
tickSizes[
{
"begin":"0",
"end":"1",
"tickSize":0.0001,
"type":"CLOSED"
},
{
"begin":"1",
"end":"Infinity",
"tickSize":0.01,
"type":"OPEN"
}
]
股票专有,最小报价单位价格区间,即当挂单价格在begin和end区间时,要满足tickSize要求,begin:价格左区间,end:价格右区间,type:区间类型 OPEN/OPEN_CLOSED/CLOSED/CLOSED_OPEN(开区间/左开右闭/闭区间/左闭右开),tickSize:最小价格单位
marginabletrue是否可融资
shortabletrue能否做空
longInitialMargin1做多初始保证金
longMaintenanceMargin1做多维持保证金
shortInitialMargin0.35做空初始保证金比例
shortMaintenanceMargin0.3做空维持保证金比例(综合账号有值,环球账号合约没有值)
shortableCount10000000可做空数目
shortFeeRate0做空费率
tradingClassLRN合约的交易级别名称
tradeabletrue是否可交易(仅限于STK类别)
continuousfalse期货专有,是否连续合约
lastTradingDate2019-01-01期货专有,最后交易日
firstNoticeDate2019-01-01期货专有,第一通知日,合约在第一通知日后无法开多仓。已有的多仓会在第一通知日之前(通常为前三个交易日)被强制平仓。
lastBiddingCloseTime0期货专有,竞价截止时间
isEtffalse是否是ETF
etfLeverage3ETF杠杆倍数,仅当合约为ETF时会存在该值
discountedDayInitialMargin3069.0期货专有,日内优惠初始保证金比例
discountedDayMaintenanceMargin2790.0期货专有,日内优惠维持保证金比例
discountedTimeZoneCodeCDT期货专有,日内优惠时间时区
discountedStartAt17:30:00期货专有,日内优惠开始时间
discountedEndAt14:30:00期货专有,日内优惠结束时间

示例

// 初始化client
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(ClientConfig.DEFAULT_CONFIG);

// 获取股票合约
ContractRequest contractRequest = ContractRequest.newRequest(new ContractModel("AAPL"));
ContractResponse contractResponse = client.execute(contractRequest);
System.out.println("return stock contract:" + JSONObject.toJSONString(contractResponse));

// 获取期权合约
ContractModel model = new ContractModel("AAPL", SecType.OPT.name(),Currency.USD.name(), "20211126", 150D, Right.CALL.name());
contractRequest = ContractRequest.newRequest(model);
contractResponse = client.execute(contractRequest);
System.out.println("return option contract:" + JSONObject.toJSONString(contractResponse));

// 获取窝轮合约
ContractModel contractModel = new ContractModel("13745", SecType.WAR.name());
contractModel.setStrike(719.38D);
contractModel.setRight(Right.CALL.name());
contractModel.setExpiry("20211223");
ContractRequest contractRequest = ContractRequest.newRequest(contractModel);
ContractResponse contractResponse = client.execute(contractRequest);
System.out.println("return warrant contract:" + JSONObject.toJSONString(contractResponse));

// 获取期货合约
ContractRequest contractRequest = ContractRequest.newRequest(
        new ContractModel("JPY2306", SecType.FUT.name()), "572386");
ContractResponse contractResponse = client.execute(contractRequest);
System.out.println("return future contract:" + JSONObject.toJSONString(contractResponse));

返回示例

{
    "code":0,
    "data":{
        "closeOnly":false,
        "currency":"USD",
        "etf":false,
        "identifier":"AAPL",
        "localSymbol":"AAPL",
        "longInitialMargin":0.3,
        "longMaintenanceMargin":0.25,
        "marginable":true,
        "market":"US",
        "multiplier":1,
        "name":"Apple",
        "secType":"STK",
        "shortInitialMargin":0.35,
        "shortMaintenanceMargin":0.3,
        "symbol":"AAPL",
        "tickSizes":[
            {
                "begin":"0",
                "end":"1",
                "tickSize":0.0001,
                "type":"CLOSED"
            },
            {
                "begin":"1",
                "end":"Infinity",
                "tickSize":0.01,
                "type":"OPEN"
            }
        ],
        "tradeable":true,
        "tradingClass":"AAPL"
    },
    "message":"success",
    "sign":"cWxRpcxoN7fICIBBK9WAq18TVtG7ez7dGJaCWOjSLHR8sQINPImZmAly9ctwCseA004K1f/7MgiHz4P9u48YdG9Vm07mUYdiNGaNJ4o79hPMi6Vq5IGMGOYFw3MQ/bZr6ikndgDZS7qQwDpBfeqTTDvzfxWFOh080wHw0SzE+co=",
    "success":true,
    "timestamp":1680838347544
}

获取多个合约信息

对应的请求类:ContractsRequest

说明 获取交易需要的合约信息,只支持STK和FUT。 需要注意环球账户、综合账户返回ContractItem字段会不同,建议获取合约和下单使用相同的账户。

CAUTION

综合账号返回的批量合约里没有可做空数量和保证金字段

输入参数

com.tigerbrokers.stock.openapi.client.https.request.contract.ContractsRequest

参数类型是否必填描述
accountstringYes用户授权账户:572386
symbolsList<String>Yes股票代码列表 如:00700 / AAPL,单次请求上限为50
sec_typestringYesSTK/FUT
currencystringNoUSD/HKD/CNH
secret_keystringNo机构用户专用,交易员密钥

返回

com.tigerbrokers.stock.openapi.client.https.response.contract.ContractsResponse

其中数据项字段如下 com.tigerbrokers.stock.openapi.client.https.domain.contract.item.ContractItem

名称示例说明
identifierCL2109/AAPL唯一标识,股票identifier和symbol相同,期权为21位标识符,如:'AAPL 220729C00150000',期货identifier
symbolLRN股票代码,期权合约的symbol为对应标的物代码
secTypeSTKSTK 股票/OPT 期权/FUT 期货/WAR 窝轮/IOPT 牛熊证等,默认 STK
nameK12 INC股票名称
localSymbol1033环球账户专有,港股用于识别窝轮和牛熊证
currencyUSDUSD/HKD/CNH
exchangeNYSE股票交易所
primaryExchangeNYSE股票上市交易所
marketUS市场 /US/HK/CN
expiry20171117期权和期货专有,期权或期货过期日
contractMonth201804期货专有,合约交割月份
rightPUT期权专有,期权方向,CALL 或者 PUT
strike24.0期权专有,期权的行权价格
multiplier0.0期权和期货专有,每手数量
minTick0.001最小报价单位
tickSizes[
{
"begin":"0",
"end":"1",
"tickSize":0.0001,
"type":"CLOSED"
},
{
"begin":"1",
"end":"Infinity",
"tickSize":0.01,
"type":"OPEN"
}
]
股票专有,最小报价单位价格区间,即当挂单价格在begin和end区间时,要满足tickSize要求,begin:价格左区间,end:价格右区间,type:区间类型 OPEN/OPEN_CLOSED/CLOSED/CLOSED_OPEN(开区间/左开右闭/闭区间/左闭右开),tickSize:最小价格单位
marginabletrue是否可融资
shortabletrue能否做空
longInitialMargin1做多初始保证金
longMaintenanceMargin1做多维持保证金
shortInitialMargin0.35做空初始保证金比例
shortMaintenanceMargin0.3做空维持保证金比例(综合账号有值,环球账号合约没有值)
shortableCount10000000可做空数目
shortFeeRate0做空费率
tradingClassLRN合约的交易级别名称
tradeabletrue是否可交易(仅限于STK类别)
continuousfalse期货专有,是否连续合约
lastTradingDate2019-01-01期货专有,最后交易日
firstNoticeDate2019-01-01期货专有,第一通知日,合约在第一通知日后无法开多仓。已有的多仓会在第一通知日之前(通常为前三个交易日)被强制平仓。
lastBiddingCloseTime0期货专有,竞价截止时间
isEtffalse是否是ETF
etfLeverage0ETF杠杆倍数,仅当合约为ETF时会存在该值

示例

List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
symbols.add("TSLA");
ContractsModel models = new ContractsModel(symbols, SecType.STK.name());
ContractsRequest contractsRequest = ContractsRequest.newRequest(models, "13810712");
ContractsResponse contractsResponse = client.execute(contractsRequest);
System.out.println("return contracts:" + JSONObject.toJSONString(contractsResponse));

返回示例

{
    "code":0,
    "data":[
        {
            "currency":"USD",
            "etf":false,
            "identifier":"AAPL",
            "localSymbol":"AAPL",
            "market":"US",
            "multiplier":1,
            "name":"Apple Inc",
            "secType":"STK",
            "symbol":"AAPL",
            "tickSizes":[
                {
                    "begin":"0",
                    "end":"1",
                    "tickSize":0.0001,
                    "type":"CLOSED"
                },
                {
                    "begin":"1",
                    "end":"Infinity",
                    "tickSize":0.01,
                    "type":"OPEN"
                }
            ],
            "tradeable":true,
            "tradingClass":"AAPL"
        },
        {
            "currency":"USD",
            "etf":false,
            "identifier":"TSLA",
            "localSymbol":"TSLA",
            "market":"US",
            "multiplier":1,
            "name":"Tesla Motors",
            "secType":"STK",
            "symbol":"TSLA",
            "tickSizes":[
                {
                    "begin":"0",
                    "end":"1",
                    "tickSize":0.0001,
                    "type":"CLOSED"
                },
                {
                    "begin":"1",
                    "end":"Infinity",
                    "tickSize":0.01,
                    "type":"OPEN"
                }
            ],
            "tradeable":true,
            "tradingClass":"TSLA"
        }
    ],
    "message":"success",
    "sign":"Bv8H6BBfKOrMOhdJAanE0hwJiJAoKOk55/cTkJIVSmw9ENd2nmbeBI3cesqRgPq8bJ2dUBrYr+cqLVG65meXwbaFYyEenWlNyigl02IuJVoETgChuSoX1SZBTnafoVivCIj3neWG8BFdhaTNNXfBMbeSYf01+BqI6xYEc6KQxKc=",
    "success":true,
    "timestamp":1684912317872
}

获取期权/窝轮/牛熊证合约列表

对应的请求类:QuoteContractRequest

输入参数:

参数类型是否必填描述
symbolstringYes股票代码
sec_typestringYes合约类型 目前支持: (OPT 期权/ WAR 港股窝轮/ IOPT 港股牛熊证)
expiryStringNo到期日(yyyyMMdd), 如果是OPT必须有值
langstringNo语言支持: zh_CN,zh_TW,en_US, 默认: en_US

返回结果:

名称类型说明
symbolstring股票代码
namestring合约名称
exchangestring交易所
marketstring市场
secTypestring合约类型
currencystring币种
expirystring到期日(期权、窝轮、牛熊证、期货), 20171117
rightstring期权方向(期权、窝轮、牛熊证), PUT/CALL
strikestring行权价
multiplierdouble每手数量(期权、窝轮、牛熊证、期货)

请求示例:

QuoteContractResponse response = client.execute(QuoteContractRequest.newRequest("00700", SecType.WAR, "20211223"));
if (response.isSuccess()) {
  System.out.println(response.getContractItems());
} else {
  System.out.println("response error:" + response.getMessage());
}

响应示例:

{
	"code": 0,
	"data": [{
		"items": [{
			"currency": "HKD",
			"exchange": "SEHK",
			"expiry": "20211223",
			"market": "HK",
			"multiplier": 50000.0,
			"name": "MSTENCT@EC2112B.C",
			"right": "CALL",
			"secType": "WAR",
			"strike": "719.38",
			"symbol": "13745"
		}, {
			"currency": "HKD",
			"exchange": "SEHK",
			"expiry": "20211223",
			"market": "HK",
			"multiplier": 5000.0,
			"name": "JPTENCT@EC2112A.C",
			"right": "CALL",
			"secType": "WAR",
			"strike": "900.5",
			"symbol": "13680"
		}],
		"secType": "WAR",
		"symbol": "00700"
	}],
	"message": "success",
	"sign": "bxQhZiWMsT9aSVTNtt2SXVeeh5w8Ypug/6UY3nL9N7LFKB1YxBVpQoKDJ4JloFojyb/CPCGT0fCXTxboDBTZvnA4stjbh1YqbNlz2lNqmHhpxYUKMdE+w2hFKVvoYMlMPCmsY5NqSQ3S/fsSzZrJyxBRPzZ+d+0qb7VSYw9yhho=",
	"success": true,
	"timestamp": 1637686550209
}
上次编辑于: