Stocks
Get Market Status QuoteMarketRequest
Require: QuoteMarketRequest
Description
Get the maket status of a queried market, and get the most recent open time of this market
Argument
Argument | Type | Required | Description |
---|---|---|---|
market | string | Yes | US-U.S. Stocks,HK-Hongkong Stocks,CN-A-Shares, ALL-all markets |
lang | string | No | Language: zh_CN,zh_TW,en_US, By default: en_US |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteMarketResponse
source
Structured as follows:
public class QuoteMarketResponse extends TigerResponse {
@JSONField(
name = "data"
)
private List<MarketItem> marketItems;
}
Use QuoteMarketResponse.getMarketItems()
, acutal data returned is a list of marketItem
. com.tigerbrokers.stock.openapi.client.https.domain.quote.item.MarketItem
has the following attributes:
Name | Type | Description |
---|---|---|
market | string | name of the Market being queried(US, CN, HK, etc.) |
marketStatus | string | Market Status, not a constant. This information includes holidays |
status | string | Market Status, NOT_YET_OPEN,PRE_HOUR_TRADING, TRADING,MIDDLE_CLOSE,POST_HOUR_TRADING, CLOSING,EARLY_CLOSED, MARKET_CLOSED |
openTime | string | Most recent future open time MM-dd HH:mm:ss |
Use get() method of MarketItem
, in this case, getMarket()
, to acess the data. or use toString()
to convert the data to a string
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
QuoteMarketResponse response = client.execute(QuoteMarketRequest.newRequest(Market.US));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getMarketItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code": 0,
"message": "success",
"timestamp": 1525938835697,
"data": [{"market":"US","marketStatus":"Closed Independence Day","status":"CLOSING","openTime":"07-04 09:30:00 EDT"}]
}
Get Trading Calendar QuoteTradeCalendarRequest
request: QuoteTradeCalendarRequest
Description
The trading day is obtained by excluding weekends and holidays from the natural day and does not exclude temporary market closures
Argument
Argument | Type | Required | Description |
---|---|---|---|
market | Market | Yes | filter by market, you can use the enums defined in Market, such as Market.US, Market.HK, Market.CN |
begin_date | string | No | begin date of calendar,include this day. format yyyy-MM-dd, like '2022-06-01' |
end_date | string | No | end date of calendar,exclude this day. format yyyy-MM-dd |
begin_time and end_time arguments' description:
begin_time is passed | end_time is passed | description |
---|---|---|
yes | yes | begin_time, end_time are the values passed |
yes | no | end_time is 365 days after begin_time |
no | yes | begin_time is 365 days before end_time |
no | no | begin_time is the current date, end_time is 30 days after begin_time |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteTradeCalendarResponse
source
Structured as follows:
public class QuoteTradeCalendarResponse extends TigerResponse {
@JSONField(name = "data")
private List<TradeCalendar> items;
}
Use QuoteTradeCalendarResponse.getItems()
, acutal data returned is a list of TradeCalendar
. com.tigerbrokers.stock.openapi.client.https.domain.quote.item.TradeCalendar
has the following attributes:
Name | Type | Description |
---|---|---|
date | string | trade day date |
type | string | trade day type. TRADING: whole day trading; EARLY_CLOSE: close market early |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
QuoteTradeCalendarRequest request = QuoteTradeCalendarRequest.newRequest(
Market.US, "2022-06-01", "2022-06-30");
QuoteTradeCalendarResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code":0,
"message":"success",
"timestamp":1655968809209,
"data":[{"date":"2022-06-01","type":"TRADING"},{"date":"2022-06-02","type":"TRADING"},{"date":"2022-06-03","type":"TRADING"},{"date":"2022-06-06","type":"TRADING"},{"date":"2022-06-07","type":"TRADING"},{"date":"2022-06-08","type":"TRADING"},{"date":"2022-06-09","type":"TRADING"},{"date":"2022-06-10","type":"TRADING"},{"date":"2022-06-13","type":"TRADING"},{"date":"2022-06-14","type":"TRADING"},{"date":"2022-06-15","type":"TRADING"},{"date":"2022-06-16","type":"TRADING"},{"date":"2022-06-17","type":"TRADING"},{"date":"2022-06-21","type":"TRADING"},{"date":"2022-06-22","type":"TRADING"},{"date":"2022-06-23","type":"TRADING"},{"date":"2022-06-24","type":"TRADING"},{"date":"2022-06-27","type":"TRADING"},{"date":"2022-06-28","type":"TRADING"},{"date":"2022-06-29","type":"TRADING"}],
"sign":"QEHsOPx7JSp5VZ3eYatbTLXy7wK7RIgWMqQfqEuEog+tQ12ThnucHPoXpcFj8wgwUU77KhLDL6KVgNBPC/D1GgXKPaWPo1E77d9Nabd9OYAwqNINP//GSuEd8ai7b32EQ4uWTrF3ycQh7g7Lb7f5nvqZypmFuaphFyTEoQfwKp8="
}
Get Symbol List QuoteSymbolRequest
request: QuoteSymbolRequest
Description
Get a list of all symbols filtered by market
Argument
Argument | Type | Required | Description |
---|---|---|---|
market | string | Yes | US, HK, CN |
include_otc | boolean | No | Whether to include OTC symbols, default: false |
lang | string | No | Language: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteSymbolResponse
source
Structured as follows
public class QuoteSymbolResponse extends TigerResponse {
@JSONField(name = "data")
private List<String> symbols;
}
Use QuoteSymbolResponse.getSymbols()
to get the data returned from the server. The result is a list that contains the stock symbols
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(ClientConfig.DEFAULT_CONFIG);
QuoteSymbolResponse response = client.execute(QuoteSymbolRequest.newRequest(Market.US).includeOTC(false));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getSymbols().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Return Example
{
"code": 0,
"message": "success",
"timestamp": 1525938835697,
"data": ["A", "A.W", "AA", "AA-B", "AAAP", "AABA", "AAC", "AADR", "AAIT", "AAL", "AALCP", "AAMC", "AAME"]
}
Get Symbols and Names QuoteSymbolNameRequest
request: QuoteSymbolNameRequest
Description
Get the ticker symbols and names of all securities in the selected market
Argument
Argument | Type | Required | Description |
---|---|---|---|
market | string | Yes | US, HK, CN |
include_otc | boolean | No | Whether to include OTC symbols, default: false |
lang | string | No | Language: zh_CN,zh_TW,en_US, en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteSymbolNameResponse
source
Structured as follows
public class QuoteSymbolNameResponse extends TigerResponse {
@JSONField(name = "data")
private List<SymbolNameItem> symbolNameItems;
}
Use QuoteSymbolNameResponse.getSymbolNameItems()
to acess the data. The return of this method is a list of SymbolNameItem
objects, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.symbolNameItems
has the following attributes:
Name | Type | Description |
---|---|---|
name | string | Name |
symbol | string | Symbol |
To access the data in SymbolNameItem
object, one can use getName()
method, or use toString()
method to convert the data to a string
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(ClientConfig.DEFAULT_CONFIG);
QuoteSymbolNameResponse response = client.execute(QuoteSymbolNameRequest.newRequest(Market.US).includeOTC(false));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getSymbolNameItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code": 0,
"message": "success",
"timestamp": 1525938835697,
"data": [{"name":"CKH Holdings","symbol":"00001"},{"name":"CLP","symbol":"00002"}]
}
Get Delayed Data QuoteDelayRequest
request:
Description
Get delayed market data for U.S. stocks. An active market data permission subscription is not required. This data is only available for U.S stocks. The data is delayed by 15 minutes
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | Stock ticker symbols, U.S. stock only |
Example
List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
symbols.add("TSLA");
QuoteDelayRequest delayRequest = QuoteDelayRequest.newRequest(symbols);
QuoteDelayResponse response = client.execute(delayRequest);
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteDelayResponse
source
Structured as follows:
public class QuoteDelayResponse extends TigerResponse {
@JSONField(name = "data")
private List<QuoteDelayItem> quoteDelayItems;
}
Use TigerResponse.getQuoteDelayItems()
to access the data. This method will return a list of QuoteDelayItem
objects, wherecom.tigerbrokers.stock.openapi.client.https.domain.quote.item.quoteDelayItem
has the following attributes:
Argument | Type | Description |
---|---|---|
close | double | close price |
high | double | high price |
low | double | low price |
open | double | opening price |
preClose | double | close price of the last trading day |
time | long | time |
volume | long | volume |
Use the get method, such as getClose()
, to access the data fields in QuoteDelayItem
Response Example
[
{
"close": 156.81,
"halted": 0,
"high": 160.45,
"low": 156.36,
"open": 159.565,
"preClose": 161.94,
"symbol": "AAPL",
"time": 1637949600000,
"volume": 76959752
},
{
"close": 1081.92,
"halted": 0,
"high": 1108.7827,
"low": 1081,
"open": 1099.47,
"preClose": 1116,
"symbol": "TSLA",
"time": 1637949600000,
"volume": 11680890
}
]
Get Timeline Data QuoteTimelineRequest
request: QuoteTimelineRequest
Description
Get timeline data
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | An array of stock ticker symbols |
period | string | Yes | period. 'day' or 'day5' |
trade_session | String | No | TradeSession:PreMarket,Regular,AfterHours; Regular by default |
begin_time | long | No | Begin time (timestamp in ms), default value is to return the data starting from today |
lang | string | No | Langauge: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteTimelineResponse
source
structured as follows:
The returned data can be accessed with QuoteTimelineResponse.getTimelineItems()
. This method will return a list of TimelineItem
objects, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.TimelineItem
has the following attributes:
Name | Type | Description |
---|---|---|
symbol | string | Ticker symbol of the stocks |
period | string | period, day or 5day |
preClose | double | close price of the last trading day |
intraday | object | intraday data, see below for contained data fields |
preMarket | object | (U.S. Stocks Only) pre-market data object |
afterHours | object | (U.S. Stocks Only) after-market data object |
Use corresponding get method, such as getSymbol() to access data in TimelineItem |
intraday:
Name | Description |
---|---|
volume | Volume |
avgPrice | average price |
price | last price |
time | timestamp of the strating time of the minute |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(ClientConfig.DEFAULT_CONFIG);
QuoteTimelineResponse response = client.execute(QuoteTimelineRequest.newRequest(List.of("AAPL"), 1544129760000L));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getTimelineItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code": 0,
"data": [
{
"symbol": "AAPL",
"preMarket": {
"endTime": 1544106600000,
"beginTime": 1544086800000,
"items": [
]
},
"period": "day",
"preClose": 176.69000244140625,
"afterHours": {
"endTime": 1544144400000,
"beginTime": 1544130000000,
"items": [
{
"volume": 872772,
"avgPrice": 174.71916,
"price": 174.69,
"time": 1544130000000
},
{
"volume": 3792,
"avgPrice": 174.71893,
"price": 174.66,
"time": 1544130060000
}
]
},
"intraday": [
{
"items": [
{
"volume": 201594,
"avgPrice": 172.0327,
"price": 174.34,
"time": 1544129760000
},
{
"volume": 139040,
"avgPrice": 172.03645,
"price": 174.4156,
"time": 1544129820000
},
{
"volume": 178427,
"avgPrice": 172.0413,
"price": 174.44,
"time": 1544129880000
},
{
"volume": 2969567,
"avgPrice": 172.21619,
"price": 174.72,
"time": 1544129940000
}
]
}
]
}
],
"timestamp": 1544185099595,
"message": "success"
}
Get Historical Timeline Data QuoteHistoryTimelineRequest
request: QuoteHistoryTimelineRequest
Description
Obtain historical time-sharing data of 1 minute
parameter
parameter | type | required | description |
---|---|---|---|
symbols | array | Yes | Stock symbol list |
date | string | Yes | year, month, day yyyyMMdd, such as 20220420 |
right | RightOption | No | Before restoration: br, No restoration: nr; Default: nr |
return
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteHistoryTimelineResponse
[source](https://github.com/tigerfintech/openapi-java-sdk/blob/master/src/main/java/com /tigerbrokers/stock/openapi/client/https/response/quote/QuoteHistoryTimelineResponse.java)
The specific structure is as follows:
The returned data can be accessed through the QuoteHistoryTimelineResponse.getTimelineItems()
method, which returns a List containing HistoryTimelineItem
objects, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.HistoryTimelineItem
properties are as follows:
Field | Type | Description |
---|---|---|
symbol | string | stock code |
items | TimelinePoint | Intraday time-sharing array, please refer to the description below for the fields |
The specific fields of TimelineItem
can be accessed through the get method of the object, such as getSymbol()
Time-sharing data items field TimelinePoint:
Timeshare field | Description |
---|---|
volume | Volume |
avgPrice | average transaction price |
price | Latest Price |
time | current time-sharing time |
example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
QuoteHistoryTimelineRequest request = QuoteHistoryTimelineRequest.newRequest(symbols, "20220420");
request.withRight(RightOption.br);
QuoteHistoryTimelineResponse response = client. execute(request);
if (response. isSuccess()) {
System.out.println(Arrays.toString(response.getTimelineItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response
{
"code": 0,
"message": "success",
"timestamp": 1651737871819,
"data":[
{
"symbol": "AAPL",
"items":[
{
"time": 1650461400000,
"volume": 1414143,
"price": 168.75,
"avgPrice": 168.66885
},
{
"time": 1650461460000,
"volume":392862,
"price": 168.25,
"avgPrice": 168.65086
},
// ....
{
"time": 1650484680000,
"volume": 443549,
"price": 167.24,
"avgPrice": 167.47902
},
{
"time": 1650484740000,
"volume":6457118,
"price": 167.23,
"avgPrice": 167.45808
}
]
}
]
}
Get Realtime Quote QuoteRealTimeQuoteRequest
request: QuoteRealTimeQuoteRequest
Description
Get real-time data for a stock/stocks. An active market quote permission is required.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | list of stock ticker symbols (maximum 50 per request) |
includeHourTrading | Boolean | No | Whether to include U.S. stocks before and after the market data, default: false |
lang | string | No | language: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteRealTimeQuoteResponse
source
Use QuoteRealTimeQuoteResponse.getRealTimeQuoteItems()
to access data. The method returns a RealTimeQuoteItem
object,where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.RealTimeQuoteItem
has the following attributes:
Name | Type | Description |
---|---|---|
symbol | string | stock ticker symbol |
open | double | opening price |
high | double | high price |
low | double | low price |
close | double | close price |
preClose | double | close price of last trading day |
latestPrice | double | last price |
latestTime | long | latest trade time |
askPrice | double | ask price |
askSize | long | ask size |
bidPrice | double | bid price |
bidSize | long | bid size |
volume | long | volume |
status | string | status |
hourTrading | object | U.S. stocks pre-market and post-market data(Response hourTrading only before and after the market time) |
hourTrading
has the following attributes:
Name | Type | Description |
---|---|---|
tag | string | pre-market("Pre-Mkt")、post-market("Post-Mkt") tag |
latestPrice | double | last price |
preClose | double | close price of the last trading day |
latestTime | string | latest trade time |
volume | long | trading volume |
timestamp | long | latest trade time in timestamp(ms) |
Use the get method, getSymbol()
to access the actual data
Example
QuoteRealTimeQuoteResponse response = client.execute(QuoteRealTimeQuoteRequest.newRequest(List.of("AAPL"), true));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getRealTimeQuoteItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response
{
"code":0,
"data":[
{
"askPrice":174.8,
"latestPrice":175.08,
"symbol":"AAPL",
"bidSize":200,
"bidPrice":174.71,
"volume":116803357,
"high":175.96,
"preClose":171.18,
"low":170.7,
"hourTrading":{
"volume":3418089,
"latestPrice":174.72,
"preClose":175.08,
"latestTime":"18:50 EST",
"tag":"Post-Mkt",
"timestamp":1639007439976
},
"latestTime":1638997200000,
"close":175.08,
"askSize":200,
"open":172.125,
"status":"NORMAL"
}
],
"success":true,
"sign":"BxcUz9YfmWcnSsmQKLcnFnVpHAT5bDdX69YntqaVIVdVqMlhSaaaW8ur3yaWP6GB6NAec2ds6s1ZB/4X40kg8lHb6u6y2V0hvHE2Q3uDNgkoukmDcAetdwRo/MAiqtQRACFGAd/AOlyhDsJyuzTf7T14zDMl5cfOfbwe2+RDjgg=",
"message":"success",
"timestamp":1639007449806
}
Get Bars QuoteKlineRequest
Description
Get K-line (bar) Data, including different time periods, such as daily, weekly, minute, etc.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | A list of symbols. Maximum 50 per request, 10 for A-Shares |
period | string | Yes | K line period, possible values are: day, week, month, year, 1min, 3min, 5min, 15min, 30min, 60min, 120min, 240min |
trade_session | string | No | TradeSession:PreMarket,Regular,AfterHours; Regular by default, PreMarket and AfterHours only support 1-minute K-line |
right | string | No | Adjuestment type. Default value is forward adjustment. br: forward adjust,nr: No adjustment |
begin_time | long | No | Begin time. Unix time stamp in millisecond or a date string. Example: 1639371600000, default value is -1, which means unbounded. |
end_time | long | No | End time. Unix time stamp in millisecond or a date string. Example: 1639371600000, default value is -1, which means unbounded. |
limit | integer | No | The maximum number of bars returned. Default value is 300. Maximum is 1200 |
lang | string | No | Language: zh_CN,zh_TW,en_US. en_US by default |
pageToken | string | No | Paging query token (only a single symbol is supported, while using 'begin_time' query), other query conditions cannot be changed when using pageToken to pull data by paging |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteKlineResponse
source
Use QuoteKlineResponse.getKlineItems()
to access the data. This method returns a KlineItem
object list, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.KlineItem
has the following attributes :
Name | Type | Description |
---|---|---|
symbol | string | Symbol |
period | string | K-line period |
nextPageToken | string | the page token used for querying the next page, if there is no more data, return null |
items | array | array that contains the KlinePoint object |
KlinePoint
have the following attributes:
Name | Type | Description |
---|---|---|
close | double | close price |
high | double | high price |
low | double | low price |
open | double | open price |
time | long | time |
volume | long | volume |
amount | double | trading amount |
Use the get method getSymbol()
to acess the actual data
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
QuoteKlineResponse response = client.execute(QuoteKlineRequest.newRequest(symbols, KType.day, "2023-05-16", "2023-05-19")
.withLimit(1000)
.withRight(RightOption.br));
if (response.isSuccess()) {
System.out.println(JSONObject.toJSONString(response));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code":0,
"data":[
{
"items":[
{
"amount":7140962535.379684,
"close":172.07,
"high":173.1383,
"low":171.7991,
"open":171.99,
"time":1684209600000,
"volume":42110293
},
{
"amount":9878512463.233082,
"close":172.69,
"high":172.925,
"low":170.4201,
"open":171.71,
"time":1684296000000,
"volume":57951604
},
{
"amount":9839606365.96335,
"close":175.05,
"high":175.24,
"low":172.58,
"open":173,
"time":1684382400000,
"volume":65496657
}
],
"period":"day",
"symbol":"AAPL"
}
],
"message":"success",
"sign":"vayBuY47WEr6fJeKKlylYqtpNHlWLbguhO9EbUQNR8Y0MdN51ju2BnPuGnNMyBZkiwBL+rG0KuUW0vbQYXGGmiIV3gfxAJA2NwXaLvOK2iQiSOzc6fAuBzyGe1etDtcvnn5apBFB5opLKVqb+lpLEhsPLzcv8rPV6I1ZCLMeQhU=",
"success":true,
"timestamp":1684831488647
}
PageToken Example
List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
QuoteKlineRequest request = QuoteKlineRequest.newRequest(symbols, KType.min1,
"2022-04-25 00:00:00",
"2022-04-28 00:00:00", TimeZoneId.NewYork);
request.withLimit(200);
request.withRight(RightOption.br);
int count = 1;
while (true) {
QuoteKlineResponse response = client.execute(request);
System.out.println(
"search time:" + count + ", success:" + response.isSuccess() + ", msg:" + response.getMessage());
if (!response.isSuccess()) {
break;
}
System.out.println(response.getKlineItems());
if (response.getKlineItems().size() == 0) {
break;
}
KlineItem klineItem = response.getKlineItems().get(0);
if (klineItem.getNextPageToken() == null) {
break;
}
count++;
// 10 times per minute
try {
TimeUnit.SECONDS.sleep(6);
} catch (InterruptedException e) {
e.printStackTrace();
}
// set pagination token then query the next page
request.withPageToken(klineItem.getNextPageToken());
}
PageToken Tools The default is 1,000 per page, and 10,000 pieces of data for paging query will be returned after the client merges. You can refer to several overloaded methods provided by the tool class. The tool method can collect up to 10,000 pieces of data at a time; in addition, pay attention to the data size setting of each page. The server will calculate a request for each paging request, which will affect the frequency of interface calls. You can implement it yourself by referring to the example, pay attention to the page turning boundary to avoid infinite loops
List<KlinePoint> list =
PageTokenUtil.getKlineByPage("AAPL", KType.min1,
"2022-04-25 00:00:00",
"2022-04-28 00:00:00", TimeZoneId.NewYork,
RightOption.br, 10, 30, PageTokenUtil.DEFAULT_TIME_INTERVAL);
for (KlinePoint item : list) {
System.out.println("content:" + item);
}
Get in-depth market data
Corresponding request class: QuoteDepthRequest
Description
Obtain the N file pending order data of the input securities code, including entrusted price, quantity and order number, and the upper limit of a single request is 50
warning CAUTION The closing auction time of Hong Kong stocks trading day is 16:00-16:10 (the market is randomly closed between 16:08 and 16:10), and the last in-depth ranking data of the day is usually updated a minute or two after 16:10
Request Frequency For frequency limit, please refer to: Request Frequency Limit
parameter
parameter | type | required | description |
---|---|---|---|
symbols | array | Yes | Stock code list (up to 50 for one time) |
market | string | Yes | US US stocks, HK stocks, CN A shares, ALL (refer to the Market enumeration class) |
return
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteDepthResponse
source
The specific structure is as follows
public class QuoteDepthResponse extends TigerResponse {
@JSONField(name = "data")
private List<QuoteDepthItem> quoteDepthItems;
}
The returned data can be accessed through the QuoteDepthResponse.getQuoteDepthItems()
method, which returns a List containing QuoteDepthItem
objects, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.QuoteDepthItem
properties are as follows:
Field | Type | Description |
---|---|---|
symbol | string | stock code |
asks | list | |
bids | list | buy order |
The order details fields are as follows:
Field | Type | Description |
---|---|---|
price | double | order price |
volume | long | order volume |
count | int | Number of entrusted orders (only available in the Hong Kong stock market, not available in the US stock market) |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
List<String> symbols = new ArrayList<>();
symbols.add("DD");
QuoteDepthResponse response = client.execute(QuoteDepthRequest.newRequest(symbols, Market.US.name()));
if (response. isSuccess()) {
for (QuoteDepthItem item : response. getQuoteDepthItems()) {
System.out.println(item.getSymbol());
System.out.println(Arrays.toString(item.getAsks().toArray()));
System.out.println(Arrays.toString(item.getBids().toArray()));
}
} else {
System.out.println("response error:" + response.getMessage());
}
Response
{
"code": 0,
"message": "success",
"timestamp": 1653064415298,
"data":[
{"symbol":"DD",
"asks":[{"price":62.88,"count":0,"volume":50},{"price":62.88,"count":0,"volume":27},{"price": 62.89,"count":0,"volume":50},{"price":62.89,"count":0,"volume":200},{"price":62.89,"count":0,"volume ":100},{"price":62.9,"count":0,"volume":50},{"price":62.9,"count":0,"volume":10},{"price": 62.91,"count":0,"volume":50},{"price":62.91,"count":0,"volume":100},{"price":62.92,"count":0,"volume ":50},{"price":62.92,"count":0,"volume":50},{"price":62.92,"count":0,"volume":100},{"price": 62.93,"count":0,"volume":50},{"price":62.93,"count":0,"volume":49},{"price":62.93,"count":0,"volume ":100},{"price":62.94,"count":0,"volume":50},{"price":62.94,"count":0,"volume":300},{"price": 62.95,"count":0,"volume":50},{"price":62.96,"count":0,"volume":50},{"price":62.97,"count":0,"volume ":50},{"price":62.98,"count":0,"volume":50},{"price":62.99,"count":0,"volume":50},{"price": 62.99,"count":0,"volume":100},{"price":63.0,"count":0,"volume":50},{"price":63.01,"count":0,"volume ":50},{"price":63.02,"count":0,"volume":100},{"price":63.02,"count":0,"volume":50},{"price": 63.03,"count":0,"volume":100},{"price":63.03,"count":0,"volume":50},{"price":63.05,"count":0,"volume ":18},{"price":63.05,"count":0,"volume":100},{"price":63.07,"count":0,"volume":200},{"price": 63.16,"count":0,"volume":100},{"price":63.32,"count":0,"volume":100},{"price":63.32,"count":0,"volume ":100},{"price":63.48,"count":0,"volume":100},{"price":63.5,"count":0,"volume":100},{"price": 63.88,"count":0,"volume":800},{"price":63.88,"count":0,"volume":100},{"price":64.14,"count":0,"volume ":100}],
"bids":[{"price":62.86,"count":0,"volume":50},{"price":62.86,"count":0,"volume":200},{"price": 62.86,"count":0,"volume":2},{"price":62.86,"count":0,"volume":6},{"price":62.85,"count":0,"volume ":50},{"price":62.84,"count":0,"volume":50},{"price":62.84,"count":0,"volume":100},{"price": 62.83,"count":0,"volume":50},{"price":62.82,"count":0,"volume":50},{"price":62.82,"count":0,"volume ":300},{"price":62.81,"count":0,"volume":50},{"price":62.8,"count":0,"volume":50},{"price": 62.79,"count":0,"volume":50},{"price":62.78,"count":0,"volume":50},{"price":62.77,"count":0,"volume ":50},{"price":62.76,"count":0,"volume":50},{"price":62.76,"count":0,"volume":100},{"price": 62.75,"count":0,"volume":50},{"price":62.75,"count":0,"volume":100},{"price":62.74,"count":0,"volume ":50},{"price":62.73,"count":0,"volume":50},{"price":62.73,"count":0,"volume":100},{"price": 62.7,"count":0,"volume":100},{"price":62.67,"count":0,"volume":50},{"price":62.67,"count":0,"volume ":200},{"price":62.62,"count":0,"volume":11},{"price":62.62,"count":0,"volume":100},{"price": 62.61,"count":0,"volume":100},{"price":62.59,"count":0,"volume":100},{"price":62.58,"count":0,"volume ":45},{"price":62.5,"count":0,"volume":20},{"price":62.27,"count":0,"volume":100},{"price": 62.25,"count":0,"volume":100},{"price":62.25,"count":0,"volume":100},{"price":62.1,"count":0,"volume ":500},{"price":62.1,"count":0,"volume":10},{"price":62.0,"count":0,"volume":8},{"price": 61.94,"count":0,"volume":100},{"price":61.9,"count":0,"volume":100},{"price":61.74,"count":0,"volume ":800}]
}
]
}
Get Trade Ticks QuoteTradeTickRequest
request:QuoteDepthRequest
Description
Get the tick data of selected stocks
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | An array of ticker symbol of a list of stocks |
trade_session | String | No | TradeSession:PreMarket,Regular,AfterHours; Regular by default |
limit | integer | No | Maximum number of data points, 2000 by default. Returns the number of recent deals for each symbol. |
lang | string | No | Language: zh_CN,zh_TW,en_US, en_US by default |
beginIndex and endIndex parameter usage instructions
Query method | beginIndex | endIndex | Description |
---|---|---|---|
Query the latest record by record | -1 | -1 | By default, return the latest record by limit. limit is 200 by default |
Query each day according to the interval | Specific value | Specific value | For example: beginIndex=10, endIndex=100, 90 records including 10 to 99 will be returned. If limit is set to 20, 20 records from 10 to 29 will be returned. |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteTradeTickResponse
source
Structured as follows:
public class QuoteTradeTickResponse extends TigerResponse {
@JSONField(name = "data")
private List<TradeTickItem> tradeTickItems;
}
Use QuoteTradeTickResponse.getTradeTickItems()
to access returned data. The method will return a TradeTickItem
object,com.tigerbrokers.stock.openapi.client.https.domain.quote.item.TradeTickItem
has the following attributes:
Name | Type | Description |
---|---|---|
beginIndex | long | Start index of the returned data |
endIndex | long | End index of the returned data |
symbol | string | Stock ticker symbol |
items | List<TickPoint> | List contains the acutal data, a TickPoint corresponds to a data point |
TickPoint
has the following attributes:
Name | Type | Description |
---|---|---|
time | long | Trading time |
price | double | Price |
volume | long | Volume |
type | string | Direction of the price change, "+" stands for "active buy", "-" stands for "active sell", "*" stands for "neutral transaction" |
Use the get method, getTime()
to access the data, or use toString()
method to convert the data to a string
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
List<String> symbols = new ArrayList<>();
symbols.add("AAPL");
QuoteTradeTickRequest request = QuoteTradeTickRequest.newRequest(symbols, 0, 30, 10);
request.setTradeSession(TradeSession.Regular);
QuoteTradeTickResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(JSONObject.toJSONString(response));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code": 0,
"data": [
{
"beginIndex": 0,
"endIndex": 10,
"items": [
{
"price": 169.59,
"time": 1712323800003,
"type": "*",
"volume": 32
},
{
"price": 169.59,
"time": 1712323800003,
"type": "*",
"volume": 8
},
{
"price": 169.59,
"time": 1712323800003,
"type": "*",
"volume": 148
},
{
"price": 169.59,
"time": 1712323800003,
"type": "*",
"volume": 1010
},
{
"price": 169.59,
"time": 1712323800005,
"type": "*",
"volume": 600
},
{
"price": 169.59,
"time": 1712323800007,
"type": "*",
"volume": 32
},
{
"price": 169.59,
"time": 1712323800008,
"type": "*",
"volume": 33
},
{
"price": 169.59,
"time": 1712323800011,
"type": "*",
"volume": 12
},
{
"price": 169.59,
"time": 1712323800011,
"type": "*",
"volume": 186
},
{
"price": 169.59,
"time": 1712323800012,
"type": "*",
"volume": 40
}
],
"symbol": "AAPL"
}
],
"message": "success",
"sign": "XEEDI1HLzWT8rkZp4boFge4OehCeXOVuXJ6U4Lgve1vUz898Ne8Q4CF/f/OIUVcHfC7XbrjqYmHJBwDdQEdfucRdsKH7g0SimlMAnyimNnya4lKIaQ6CRbfE5faEe2sdopjnwZggFkycnCeB0JhiTK72xR5uTC0gGlcaaPY36o4=",
"success": true,
"timestamp": 1712557783317
}
Get Trading Requirement QuoteStockTradeRequest
Description
Get the required information for trading, such as lot size, for a tradable asset.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbols | array | Yes | Symbols, maximum number supported is 50 |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteStockTradeResponse
source
Structured as follows:
public class QuoteStockTradeResponse extends TigerResponse {
@JSONField(name = "data")
private List<QuoteStockTradeItem> stockTradeItems;
public List<QuoteStockTradeItem> getStockTradeItems() {
return stockTradeItems;
}
}
Use QuoteStockTradeResponse.getStockTradeItems()
to access the response. The data is contained in QuoteStockTradeItem
objects,com.tigerbrokers.stock.openapi.client.https.domain.quote.item.QuoteStockTradeItem
has the following attributes:
Name | Type | Description |
---|---|---|
symbol | String | symbol |
lotSize | Integer | lotsize |
spreadScale | Integer | tick size |
minTick | Double | minimum tick |
Use the get method getSymbol()
to access, or use toString()
method to convert the data to a string.
Example
List<String> symbols = new ArrayList<>();
symbols.add("00700");
symbols.add("00810");
QuoteStockTradeResponse response = client.execute(QuoteStockTradeRequest.newRequest(symbols));
if (response.isSuccess()) {
System.out.println(Arrays.toString(response.getStockTradeItems().toArray()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"code": 0,
"data": [{
"lotSize": 100,
"minTick": 0.2,
"spreadScale": 0,
"symbol": "00700"
}, {
"lotSize": 6000,
"minTick": 0.001,
"spreadScale": 0,
"symbol": "00810"
}],
"message": "success",
"timestamp": 1546853907390
}
Get Capital Flow QuoteCapitalFlowRequest
Description
Get capital net inflow Data, including different time periods, such as daily, weekly, monthly, etc.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | symbol |
period | string | Yes | period, possible values are: intraday, day, week, month, year, quarter, 6month |
market | string | Yes | US-U.S. Stocks, HK-Hongkong Stocks, CN-A-Shares |
begin_time | long | No | Begin time. Unix time stamp in millisecond or a date string. Example: 1639371600000, default value is -1, which means unbounded. |
end_time | long | No | End time. Unix time stamp in millisecond or a date string. Example: 1639371600000, default value is -1, which means unbounded. |
limit | integer | No | The maximum number of points returned. Default value is 200. Maximum is 1200 |
lang | string | No | Language: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteCapitalFlowResponse
source
Use QuoteCapitalFlowResponse.getCapitalFlowItem()
to access the data. This method returns a CapitalFlowItem
object, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.CapitalFlowItem
has the following attributes :
Name | Type | Description |
---|---|---|
symbol | string | symbol |
period | string | capital period |
items | array | array that contains the capital flow data |
items has the following attributes:
Name | Type | Description |
---|---|---|
netInflow | double | net inflow |
time | string | time, "11-25 12:48:00 EST" |
timestamp | long | timestamp |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
// real-time data
QuoteCapitalFlowRequest request = QuoteCapitalFlowRequest.newRequest(
"AAPL", Market.US, CapitalPeriod.intraday);
QuoteCapitalFlowResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(JSONObject.toJSON(response.getCapitalFlowItem()));
} else {
System.out.println("response error:" + response.getMessage());
}
// net capital inflow data in the last 10 days
QuoteCapitalFlowRequest request = QuoteCapitalFlowRequest.newRequest(
"00700", Market.HK, CapitalPeriod.day);
request.setLimit(10);
QuoteCapitalFlowResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(JSONObject.toJSON(response.getCapitalFlowItem()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
// real-time data
{
"symbol":"AAPL",
"items":[
{
"netInflow":-109057032.2042,
"time":"11-25 09:30:00 EST",
"timestamp":1669386600000
},
{
"netInflow":-116890065.471,
"time":"11-25 09:31:00 EST",
"timestamp":1669386660000
}
]
}
// net capital inflow data in the last 10 days
{
"symbol":"00700",
"period":"day",
"items":[
{
"netInflow":687742300,
"time":"2022-11-14",
"timestamp":1668355200000
},
{
"netInflow":1926444000,
"time":"2022-11-15",
"timestamp":1668441600000
},
{
"netInflow":1033900840,
"time":"2022-11-16",
"timestamp":1668528000000
},
{
"netInflow":1667729580,
"time":"2022-11-17",
"timestamp":1668614400000
},
{
"netInflow":284728680,
"time":"2022-11-18",
"timestamp":1668700800000
},
{
"netInflow":661046060,
"time":"2022-11-21",
"timestamp":1668960000000
},
{
"netInflow":-86129700,
"time":"2022-11-22",
"timestamp":1669046400000
},
{
"netInflow":350223200,
"time":"2022-11-23",
"timestamp":1669132800000
},
{
"netInflow":-161005460,
"time":"2022-11-24",
"timestamp":1669219200000
},
{
"netInflow":17355680,
"time":"2022-11-25",
"timestamp":1669305600000
}
]
}
Get Capital Distribution QuoteCapitalDistributionRequest
Description
Get capital distribution.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | symbol |
market | string | Yes | US-U.S. Stocks, HK-Hongkong Stocks, CN-A-Shares |
lang | string | No | Language: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteCapitalDistributionResponse
source
Use QuoteCapitalDistributionResponse.getCapitalDistributionItem()
to access the data. This method returns a CapitalDistributionItem
object, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.CapitalDistributionItem
has the following attributes :
Name | Type | Description |
---|---|---|
symbol | string | symbol |
netInflow | double | net inflow(inAll - outAll) |
inAll | double | all inflow(inBig + inMid + inSmall) |
inBig | double | big orders's inflow |
inMid | double | median orders's inflow |
inSmall | double | small orders's inflow |
outAll | double | all outflow(outBig + outMid + outSmall) |
outBig | double | big orders's outflow |
outMid | double | median orders's outflow |
outSmall | double | small orders's outflow |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
QuoteCapitalDistributionRequest request = QuoteCapitalDistributionRequest.newRequest(
"00700", Market.HK);
QuoteCapitalDistributionResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(JSONObject.toJSON(response.getCapitalDistributionItem()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"inBig":721190520,
"netInflow":481406280,
"symbol":"00700",
"outBig":464624440,
"outAll":3639820460,
"inAll":4121226740,
"inMid":604918520,
"inSmall":2795117700,
"outMid":572017220,
"outSmall":2603178800
}
Get Stock Broker QuoteStockBrokerRequest
Description
Get stock broker infomation.
Argument
Argument | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | symbol |
limit | integer | No | The maximum number of points returned. Default value is 40. Maximum is 60 |
lang | string | No | Language: zh_CN,zh_TW,en_US. en_US by default |
Response
com.tigerbrokers.stock.openapi.client.https.response.quote.QuoteStockBrokerResponse
source
Use QuoteStockBrokerResponse.getStockBrokerItem()
to access the data. This method returns a StockBrokerItem
object, where com.tigerbrokers.stock.openapi.client.https.domain.quote.item.StockBrokerItem
has the following attributes :
Name | Type | Description |
---|---|---|
symbol | string | symbol |
bidBroker | array | array that contains the 'LevelBroker' data |
askBroker | array | array that contains the 'LevelBroker' data |
'LevelBroker' has the following attributes:
Name | Type | Description |
---|---|---|
level | integer | price level |
price | double | price |
brokerCount | integer | the count of borkers |
broker | array | the list of borkers |
Example
TigerHttpClient client = TigerHttpClient.getInstance().clientConfig(
ClientConfig.DEFAULT_CONFIG);
QuoteStockBrokerRequest request = QuoteStockBrokerRequest.newRequest("00700", 10, Language.en_US);
QuoteStockBrokerResponse response = client.execute(request);
if (response.isSuccess()) {
System.out.println(JSONObject.toJSON(response.getStockBrokerItem()));
} else {
System.out.println("response error:" + response.getMessage());
}
Response Example
{
"bidBroker":[
{
"level":1,
"price":287.8,
"brokerCount":7,
"broker":[
{
"name":"China Investment",
"id":"6997"
},
{
"name":"China Investment",
"id":"6998"
},
{
"name":"BOCI",
"id":"8134"
},
{
"name":"China Investment",
"id":"6998"
},
{
"name":"China Innovation",
"id":"5999"
},
{
"name":"China Investment",
"id":"6996"
},
{
"name":"J.P. Morgan",
"id":"5342"
}
]
},
{
"level":2,
"price":287.6,
"brokerCount":3,
"broker":[
{
"name":"China Investment",
"id":"6998"
},
{
"name":"China Investment",
"id":"6999"
},
{
"name":"China Innovation",
"id":"5998"
}
]
}
],
"symbol":"00700",
"askBroker":[
{
"level":1,
"price":288,
"brokerCount":10,
"broker":[
{
"name":"FUTU Securities",
"id":"8461"
},
{
"name":"China Innovation",
"id":"5998"
},
{
"name":"ICBC (Asia)",
"id":"8117"
},
{
"name":"China Innovation",
"id":"5998"
},
{
"name":"China Investment",
"id":"6999"
},
{
"name":"HSBC Securities Brokers",
"id":"8577"
},
{
"name":"China Investment",
"id":"6996"
},
{
"name":"China Investment",
"id":"6999"
},
{
"name":"FUTU Securities",
"id":"8462"
},
{
"name":"HSBC Securities Brokers",
"id":"8575"
}
]
}
]
}