籌碼面
在台股籌碼面,我們擁有 15 種資料集,如下:
- 個股融資融劵表 TaiwanStockMarginPurchaseShortSale
- 整體市場融資融劵表 TaiwanStockTotalMarginPurchaseShortSale
- 個股三大法人買賣表 TaiwanStockInstitutionalInvestorsBuySell
- 整體市場三大法人買賣表 TaiwanStockTotalInstitutionalInvestors
- 外資持股表 TaiwanStockShareholding
- 股權持股分級表 TaiwanStockHoldingSharesPer
- 借券成交明細 TaiwanStockSecuritiesLending
- 暫停融券賣出表(融券回補日) TaiwanStockMarginShortSaleSuspension
- 信用額度總量管制餘額表 TaiwanDailyShortSaleBalances
- 證券商資訊表 TaiwanSecuritiesTraderInfo
- 台股分點資料表(query by 股票代碼) TaiwanStockTradingDailyReport
- 台股分點資料表(query by 券商代碼) TaiwanStockTradingDailyReport
- 台股權證分點資料表(query by 股票代碼) TaiwanStockWarrantTradingDailyReport
- 台股權證分點資料表(query by 券商代碼) TaiwanStockWarrantTradingDailyReport
- 台股八大行庫賣賣表 TaiwanstockGovernmentBankBuySell
- 台灣大盤融資維持率 TaiwanTotalExchangeMarginMaintenance
- 當日卷商分點統計表 TaiwanStockTradingDailyReportSecIdAgg
個股融資融劵表 TaiwanStockMarginPurchaseShortSale¶
- 資料區間:2001-01-01 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_margin_purchase_short_sale(
stock_id="2330",
start_date='2020-04-02',
end_date='2020-04-12',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockMarginPurchaseShortSale",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockMarginPurchaseShortSale",
data_id= "2330",
start_date= "2020-01-02",
end_date= "2020-04-12",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
Output
date | stock_id | MarginPurchaseBuy | MarginPurchaseCashRepayment | MarginPurchaseLimit | MarginPurchaseSell | MarginPurchaseTodayBalance | MarginPurchaseYesterdayBalance | Note | OffsetLoanAndShort | ShortSaleBuy | ShortSaleCashRepayment | ShortSaleLimit | ShortSaleSell | ShortSaleTodayBalance | ShortSaleYesterdayBalance | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 2020-04-06 | 2330 | 1914 | 8 | 6482595 | 1269 | 26285 | 25648 | X | 0 | 0 | 24 | 6482595 | 0 | 0 | 24 |
1 | 2020-04-07 | 2330 | 1049 | 13 | 6482595 | 2655 | 24666 | 26285 | X | 0 | 0 | 0 | 6482595 | 0 | 0 | 0 |
2 | 2020-04-08 | 2330 | 1192 | 3 | 6482595 | 1569 | 24286 | 24666 | 0 | 0 | 0 | 6482595 | 0 | 0 | 0 | |
3 | 2020-04-09 | 2330 | 499 | 28 | 6482595 | 1362 | 23395 | 24286 | 209 | 0 | 0 | 6482595 | 398 | 398 | 0 | |
4 | 2020-04-10 | 2330 | 1227 | 24 | 6482595 | 794 | 23804 | 23395 | 53 | 156 | 0 | 6482595 | 156 | 398 | 398 |
{
date: str,
stock_id: str,
MarginPurchaseBuy: int64,
MarginPurchaseCashRepayment: int64,
MarginPurchaseLimit: int64,
MarginPurchaseSell: int64,
MarginPurchaseTodayBalance: int64,
MarginPurchaseYesterdayBalance: int64,
Note: str,
OffsetLoanAndShort: int64,
ShortSaleBuy: int64,
ShortSaleCashRepayment: int64,
ShortSaleLimit: int64,
ShortSaleSell: int64,
ShortSaleTodayBalance: int64,
ShortSaleYesterdayBalance: int64
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_margin_purchase_short_sale(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockMarginPurchaseShortSale",
"start_date": "2020-04-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockMarginPurchaseShortSale",
start_date= "2020-01-02",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | MarginPurchaseBuy | MarginPurchaseCashRepayment | MarginPurchaseLimit | MarginPurchaseSell | MarginPurchaseTodayBalance | MarginPurchaseYesterdayBalance | Note | OffsetLoanAndShort | ShortSaleBuy | ShortSaleCashRepayment | ShortSaleLimit | ShortSaleSell | ShortSaleTodayBalance | ShortSaleYesterdayBalance | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 2020-04-01 | 0050 | 193 | 15 | 263750 | 163 | 3189 | 3174 | 0 | 65 | 1 | 263750 | 13 | 2283 | 2336 | |
1 | 2020-04-01 | 0051 | 0 | 0 | 2375 | 0 | 5 | 5 | 0 | 0 | 0 | 2375 | 0 | 0 | 0 | |
2 | 2020-04-01 | 0052 | 0 | 0 | 7500 | 0 | 128 | 128 | 0 | 0 | 0 | 7500 | 0 | 0 | 0 | |
3 | 2020-04-01 | 0053 | 0 | 0 | 1622 | 0 | 1 | 1 | 0 | 0 | 0 | 1622 | 0 | 0 | 0 | |
4 | 2020-04-01 | 0054 | 0 | 0 | 2531 | 0 | 0 | 0 | X | 0 | 0 | 0 | 2531 | 0 | 0 | 0 |
{
date: str,
stock_id: str,
MarginPurchaseBuy: int64,
MarginPurchaseCashRepayment: int64,
MarginPurchaseLimit: int64,
MarginPurchaseSell: int64,
MarginPurchaseTodayBalance: int64,
MarginPurchaseYesterdayBalance: int64,
Note: str,
OffsetLoanAndShort: int64,
ShortSaleBuy: int64,
ShortSaleCashRepayment: int64,
ShortSaleLimit: int64,
ShortSaleSell: int64,
ShortSaleTodayBalance: int64,
ShortSaleYesterdayBalance: int64
}
台灣市場整體融資融劵表 TaiwanStockTotalMarginPurchaseShortSale¶
- 資料區間:2001-01-01 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_margin_purchase_short_sale_total(
start_date='2020-04-01',
end_date='2020-04-12',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockTotalMarginPurchaseShortSale",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockTotalMarginPurchaseShortSale",
start_date= "2020-01-02",
end_date= "2020-04-12",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
TodayBalance | YesBalance | buy | date | name | Return | sell | |
---|---|---|---|---|---|---|---|
0 | 5463820 | 5471770 | 236127 | 2020-04-01 | MarginPurchase | 10986 | 233091 |
1 | 91965082000 | 91898116000 | 4046643000 | 2020-04-01 | MarginPurchaseMoney | 196619000 | 3783058000 |
2 | 541704 | 556742 | 57266 | 2020-04-01 | ShortSale | 6151 | 48379 |
3 | 535401 | 541704 | 50779 | 2020-04-06 | ShortSale | 3700 | 48176 |
4 | 93198509000 | 91965082000 | 6440842000 | 2020-04-06 | MarginPurchaseMoney | 71638000 | 5135777000 |
{
TodayBalance: int64,
YesBalance: int64,
buy: int64,
date: str,
name: str,
Return: int64,
sell: int64
}
法人買賣表 TaiwanStockInstitutionalInvestorsBuySell¶
- 資料區間:2005-01-01 ~ now
- 資料更新時間 星期一至五 20:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_institutional_investors(
stock_id="2330",
start_date='2020-04-01',
end_date='2020-04-12',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockInstitutionalInvestorsBuySell",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockInstitutionalInvestorsBuySell",
data_id= "2330",
start_date= "2020-04-01",
end_date= "2020-04-12",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | buy | name | sell | |
---|---|---|---|---|---|
0 | 2020-04-01 | 2330 | 31304729 | Foreign_Investor | 29057663 |
1 | 2020-04-01 | 2330 | 0 | Foreign_Dealer_Self | 0 |
2 | 2020-04-01 | 2330 | 900000 | Investment_Trust | 239000 |
3 | 2020-04-01 | 2330 | 79000 | Dealer_self | 807000 |
4 | 2020-04-01 | 2330 | 189000 | Dealer_Hedging | 493500 |
{
date: str,
stock_id: str,
buy: int64,
name: str,
sell: int64
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_institutional_investors(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockInstitutionalInvestorsBuySell",
"start_date": "2020-04-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data)
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockInstitutionalInvestorsBuySell",
start_date= "2020-01-02",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | buy | name | sell | |
---|---|---|---|---|---|
0 | 2020-04-01 | 0050 | 458249 | Foreign_Investor | 4492000 |
1 | 2020-04-01 | 0050 | 0 | Foreign_Dealer_Self | 0 |
2 | 2020-04-01 | 0050 | 54000 | Investment_Trust | 0 |
3 | 2020-04-01 | 0050 | 0 | Dealer_self | 0 |
4 | 2020-04-01 | 0050 | 2050000 | Dealer_Hedging | 905000 |
{
date: str,
stock_id: str,
buy: int64,
name: str,
sell: int64
}
台灣市場整體法人買賣表 TaiwanStockTotalInstitutionalInvestors¶
- 資料區間:2004-04-01 ~ now
- 資料更新時間 星期一至五 15:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_institutional_investors_total(
start_date='2020-04-01',
end_date='2020-04-12',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockTotalInstitutionalInvestors",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockTotalInstitutionalInvestors",
start_date= "2020-01-02",
end_date='2020-04-12',
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
buy | date | name | sell | |
---|---|---|---|---|
0 | 123150 | 2020-04-01 | Foreign_Dealer_Self | 266220 |
1 | 3681729831 | 2020-04-01 | Dealer_Hedging | 5539788946 |
2 | 33759089839 | 2020-04-01 | Foreign_Investor | 38466572585 |
3 | 3039112340 | 2020-04-01 | Investment_Trust | 853138940 |
4 | 789316840 | 2020-04-01 | Dealer_self | 912143500 |
{
buy: int64,
date: str,
name: str,
sell: int64
}
外資持股表 TaiwanStockShareholding¶
- 資料區間:2004-02-01 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_shareholding(
stock_id="2330",
start_date='2020-04-01',
end_date='2020-04-12'
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockShareholding",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockShareholding",
data_id= "2330",
start_date= "2020-01-02",
end_date="2020-04-12",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | stock_name | InternationalCode | ForeignInvestmentRemainingShares | ForeignInvestmentShares | ForeignInvestmentRemainRatio | ForeignInvestmentSharesRatio | ForeignInvestmentUpperLimitRatio | ChineseInvestmentUpperLimitRatio | NumberOfSharesIssued | RecentlyDeclareDate | note | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 2020-04-01 | 2330 | 台積電 | TW0002330008 | 6309042842 | 19621337616 | 24.33 | 75.66 | 100 | 100 | 25930380458 | 2019-05-27 | |
1 | 2020-04-06 | 2330 | 台積電 | TW0002330008 | 6304552683 | 19625827775 | 24.31 | 75.68 | 100 | 100 | 25930380458 | 2019-05-27 | |
2 | 2020-04-07 | 2330 | 台積電 | TW0002330008 | 6283562246 | 19646818212 | 24.23 | 75.76 | 100 | 100 | 25930380458 | 2019-05-27 | |
3 | 2020-04-08 | 2330 | 台積電 | TW0002330008 | 6273338931 | 19657041527 | 24.19 | 75.8 | 100 | 100 | 25930380458 | 2019-05-27 | |
4 | 2020-04-09 | 2330 | 台積電 | TW0002330008 | 6267988722 | 19662391736 | 24.17 | 75.82 | 100 | 100 | 25930380458 | 2019-05-27 |
{
date: str,
stock_id: str,
stock_name: str,
InternationalCode: str,
ForeignInvestmentRemainingShares: int64,
ForeignInvestmentShares: int64,
ForeignInvestmentRemainRatio: float64,
ForeignInvestmentSharesRatio: float64,
ForeignInvestmentUpperLimitRatio: float64,
ChineseInvestmentUpperLimitRatio: float64,
NumberOfSharesIssued: int64,
RecentlyDeclareDate: str,
note: str
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_shareholding(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockShareholding",
"start_date": "2020-04-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockShareholding",
start_date= "2020-01-02",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | stock_name | InternationalCode | ForeignInvestmentRemainingShares | ForeignInvestmentShares | ForeignInvestmentRemainRatio | ForeignInvestmentSharesRatio | ForeignInvestmentUpperLimitRatio | ChineseInvestmentUpperLimitRatio | NumberOfSharesIssued | RecentlyDeclareDate | note | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 2020-04-01 | 0050 | 元大台灣50 | TW0000050004 | 960256795 | 94743205 | 91.01 | 8.98 | 100 | 100 | 1055000000 | 2019-07-18 | |
1 | 2020-04-01 | 0051 | 元大中型100 | TW0000051002 | 9471000 | 29000 | 99.69 | 0.3 | 100 | 100 | 9500000 | 2019-07-18 | |
2 | 2020-04-01 | 0052 | 富邦科技 | TW0000052000 | 29957000 | 43000 | 99.85 | 0.14 | 100 | 100 | 30000000 | 2019-07-18 | |
3 | 2020-04-01 | 0053 | 元大電子 | TW0000053008 | 6466950 | 21050 | 99.67 | 0.32 | 100 | 100 | 6488000 | 2019-07-18 | |
4 | 2020-04-01 | 0054 | 元大台商50 | TW0000054006 | 9955000 | 169000 | 98.33 | 1.66 | 100 | 100 | 10124000 | 2019-07-18 |
{
date: str,
stock_id: str,
stock_name: str,
InternationalCode: str,
ForeignInvestmentRemainingShares: int64,
ForeignInvestmentShares: int64,
ForeignInvestmentRemainRatio: float64,
ForeignInvestmentSharesRatio: float64,
ForeignInvestmentUpperLimitRatio: float64,
ChineseInvestmentUpperLimitRatio: float64,
NumberOfSharesIssued: int64,
RecentlyDeclareDate: str,
note: str
}
股東持股分級表 TaiwanStockHoldingSharesPer(只限 backer、sponsor 會員使用)¶
- 資料區間:2001-01-01 ~ now
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_holding_shares_per(
stock_id="2330",
start_date='2020-04-01',
end_date='2020-04-12'
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockHoldingSharesPer",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockHoldingSharesPer",
data_id= "2330",
start_date= "2020-01-02",
end_date='2020-04-12',
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | HoldingSharesLevel | people | percent | unit | |
---|---|---|---|---|---|---|
0 | 2020-04-01 | 2330 | 1-999 | 165122 | 0.12 | 33289900 |
1 | 2020-04-01 | 2330 | 1,000-5,000 | 227692 | 1.69 | 440404454 |
2 | 2020-04-01 | 2330 | 10,001-15,000 | 10408 | 0.49 | 128127693 |
3 | 2020-04-01 | 2330 | 100,001-200,000 | 1628 | 0.86 | 225202876 |
4 | 2020-04-01 | 2330 | 15,001-20,000 | 5068 | 0.34 | 89929303 |
{
date: str,
stock_id: str,
HoldingSharesLevel: str,
people: int64,
percent: float64,
unit: int64
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_holding_shares_per(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockHoldingSharesPer",
"data_id": "2330",
"start_date": "2020-04-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data)
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockHoldingSharesPer",
start_date= "2020-04-01",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | HoldingSharesLevel | people | percent | unit | |
---|---|---|---|---|---|---|
0 | 2020-04-01 | 0050 | 1-999 | 44173 | 1.02 | 10834763 |
1 | 2020-04-01 | 0050 | 1,000-5,000 | 96465 | 17.7 | 186791648 |
2 | 2020-04-01 | 0050 | 5,001-10,000 | 10364 | 7.57 | 79902735 |
3 | 2020-04-01 | 0050 | 10,001-15,000 | 2819 | 3.41 | 36075583 |
4 | 2020-04-01 | 0050 | 15,001-20,000 | 1557 | 2.69 | 28426726 |
{
date: str,
stock_id: str,
HoldingSharesLevel: str,
people: int64,
percent: float64,
unit: int64
}
借券成交明細 TaiwanStockSecuritiesLending¶
- 資料區間:2001-05-01 ~ now
- 資料更新時間 星期一至五 15:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_securities_lending(
stock_id="2330",
start_date='2020-04-01',
end_date='2020-04-12'
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockSecuritiesLending",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockSecuritiesLending",
data_id="2330",
start_date= "2020-01-02",
end_date='2020-04-12',
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | transaction_type | volume | fee_rate | close | original_return_date | original_lending_period | |
---|---|---|---|---|---|---|---|---|
0 | 2020-04-01 | 2330 | 議借 | 1330 | 1.36 | 271.5 | 2020-09-30 | 182 |
1 | 2020-04-01 | 2330 | 議借 | 800 | 0.41 | 271.5 | 2020-09-30 | 182 |
2 | 2020-04-01 | 2330 | 議借 | 850 | 0.41 | 271.5 | 2020-09-30 | 182 |
3 | 2020-04-01 | 2330 | 議借 | 500 | 0.5 | 271.5 | 2020-09-30 | 182 |
4 | 2020-04-01 | 2330 | 議借 | 160 | 0.36 | 271.5 | 2020-09-30 | 182 |
{
date: str,
stock_id: str,
transaction_type: str,
volume: int64,
fee_rate: float64,
close: float64,
original_return_date: str,
original_lending_period: int64
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_securities_lending(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockSecuritiesLending",
"start_date": "2020-04-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data)
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockSecuritiesLending",
start_date= "2020-01-02",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | transaction_type | volume | fee_rate | close | original_return_date | original_lending_period | |
---|---|---|---|---|---|---|---|---|
0 | 2020-04-01 | 1101 | 議借 | 760 | 0.25 | 39 | 2020-09-30 | 182 |
1 | 2020-04-01 | 1101 | 議借 | 397 | 0.25 | 39 | 2020-09-30 | 182 |
2 | 2020-04-01 | 1101 | 競價 | 436 | 0.7 | 39 | 2020-09-30 | 182 |
3 | 2020-04-01 | 1102 | 議借 | 150 | 0.25 | 38.6 | 2020-09-30 | 182 |
4 | 2020-04-01 | 1102 | 議借 | 770 | 1.05 | 38.6 | 2020-09-30 | 182 |
{
date: str,
stock_id: str,
transaction_type: str,
volume: int64,
fee_rate: float64,
close: float64,
original_return_date: str,
original_lending_period: int64
}
暫停融券賣出表(融券回補日) TaiwanStockMarginShortSaleSuspension¶
- 資料區間:2015-01-01 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockMarginShortSaleSuspension",
"data_id": "0050",
"start_date": "2015-01-01",
"end_date": "2015-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockMarginShortSaleSuspension",
data_id="0050",
start_date= "2015-01-01",
end_date= "2015-04-12",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
stock_id | date | end_date | reason | |
---|---|---|---|---|
0 | 0050 | 2015-10-20 | 2015-10-23 | 分配收益 |
1 | 0050 | 2016-07-22 | 2016-07-27 | 分配收益 |
2 | 0050 | 2017-02-02 | 2017-02-07 | 分配收益 |
3 | 0050 | 2017-07-25 | 2017-07-28 | 分配收益 |
4 | 0050 | 2018-01-23 | 2018-01-26 | 分配收益 |
{
stock_id: str,
date: str, # 開始日期
end_date: str,
reason: str
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockMarginShortSaleSuspension",
"start_date": "2015-10-20",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data)
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockMarginShortSaleSuspension",
start_date= "2015-10-20",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
stock_id | date | end_date | reason | |
---|---|---|---|---|
0 | 0050 | 2015-10-20 | 2015-10-23 | 分配收益 |
1 | 0056 | 2015-10-20 | 2015-10-23 | 分配收益 |
{
stock_id: str,
date: str, # 開始日期
end_date: str,
reason: str
}
信用額度總量管制餘額表 TaiwanDailyShortSaleBalances¶
- 資料區間:2005-07-01 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_daily_short_sale_balances(
stock_id="2330",
start_date='2020-04-01',
end_date='2020-04-12',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanDailyShortSaleBalances",
"data_id": "2330",
"start_date": "2020-04-01",
"end_date": "2020-04-12",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanDailyShortSaleBalances",
data_id="2330",
start_date= "2020-01-02",
end_date='2020-04-12',
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
stock_id | MarginShortSalesPreviousDayBalance | MarginShortSalesShortSales | MarginShortSalesShortCovering | MarginShortSalesStockRedemption | MarginShortSalesCurrentDayBalance | MarginShortSalesQuota | SBLShortSalesPreviousDayBalance | SBLShortSalesShortSales | SBLShortSalesReturns | SBLShortSalesAdjustments | SBLShortSalesCurrentDayBalance | SBLShortSalesQuota | SBLShortSalesShortCovering | date | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 2330 | 1975000 | 0 | 1573000 | 378000 | 24000 | -2107339478 | 47947858 | 487000 | 0 | 0 | 48434858 | 7526895 | 0 | 2020-04-01 |
1 | 2330 | 24000 | 0 | 0 | 24000 | 0 | -2107339478 | 48434858 | 44000 | 60000 | 0 | 48418858 | 7563083 | 0 | 2020-04-06 |
2 | 2330 | 0 | 0 | 0 | 0 | 0 | -2107339478 | 48418858 | 62000 | 0 | 0 | 48480858 | 7635835 | 0 | 2020-04-07 |
3 | 2330 | 0 | 0 | 0 | 0 | 0 | -2107339478 | 48480858 | 933000 | 7345000 | 0 | 42068858 | 7688249 | 0 | 2020-04-08 |
4 | 2330 | 0 | 398000 | 0 | 0 | 398000 | -2107339478 | 42068858 | 46000 | 2000 | 0 | 42112858 | 7642682 | 0 | 2020-04-09 |
{
stock_id: str,
MarginShortSalesPreviousDayBalance: int32,
MarginShortSalesShortSales: int32,
MarginShortSalesShortCovering: int32,
MarginShortSalesStockRedemption: int32,
MarginShortSalesCurrentDayBalance: int32,
MarginShortSalesQuota: int32,
SBLShortSalesPreviousDayBalance: int32,
SBLShortSalesShortSales: int32,
SBLShortSalesReturns: int32,
SBLShortSalesAdjustments: int32,
SBLShortSalesCurrentDayBalance: int32,
SBLShortSalesQuota: int32,
SBLShortSalesShortCovering: int32,
date: str
}
一次拿特定日期,所有資料(只限 backer、sponsor 會員使用)¶
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_daily_short_sale_balances(
start_date='2020-04-01',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanDailyShortSaleBalances",
"start_date": "2021-05-20",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data)
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanDailyShortSaleBalances",
start_date= "2020-01-02",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
stock_id | MarginShortSalesPreviousDayBalance | MarginShortSalesShortSales | MarginShortSalesShortCovering | MarginShortSalesStockRedemption | MarginShortSalesCurrentDayBalance | MarginShortSalesQuota | SBLShortSalesPreviousDayBalance | SBLShortSalesShortSales | SBLShortSalesReturns | SBLShortSalesAdjustments | SBLShortSalesCurrentDayBalance | SBLShortSalesQuota | SBLShortSalesShortCovering | date | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
0 | 0050 | 2336000 | 13000 | 65000 | 1000 | 2283000 | 263750000 | 25527000 | 0 | 0 | 0 | 25527000 | 2397551 | 0 | 2020-04-01 |
1 | 0051 | 0 | 0 | 0 | 0 | 0 | 2375000 | 1000 | 0 | 0 | 0 | 1000 | 4053 | 0 | 2020-04-01 |
2 | 0052 | 0 | 0 | 0 | 0 | 0 | 7500000 | 34000 | 0 | 0 | 0 | 34000 | 17168 | 0 | 2020-04-01 |
3 | 0053 | 0 | 0 | 0 | 0 | 0 | 1622000 | 0 | 0 | 0 | 0 | 0 | 3158 | 0 | 2020-04-01 |
4 | 0054 | 0 | 0 | 0 | 0 | 0 | 2531000 | 0 | 0 | 0 | 0 | 0 | 1357 | 0 | 2020-04-01 |
{
stock_id: str,
MarginShortSalesPreviousDayBalance: int32,
MarginShortSalesShortSales: int32,
MarginShortSalesShortCovering: int32,
MarginShortSalesStockRedemption: int32,
MarginShortSalesCurrentDayBalance: int32,
MarginShortSalesQuota: int32,
SBLShortSalesPreviousDayBalance: int32,
SBLShortSalesShortSales: int32,
SBLShortSalesReturns: int32,
SBLShortSalesAdjustments: int32,
SBLShortSalesCurrentDayBalance: int32,
SBLShortSalesQuota: int32,
SBLShortSalesShortCovering: int32,
date: str
}
證券商資訊表 TaiwanSecuritiesTraderInfo¶
- 提供證券商相關資訊,用於台股分點資料表(TaiwanStockTradingDailyReport ),使用卷商代碼,查詢特定卷商所有股票進出。
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_securities_trader_info()
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanSecuritiesTraderInfo",
"token": "", # 參考登入,獲取金鑰
}
resp = requests.get(url, params=parameter)
data = resp.json()
data = pd.DataFrame(data["data"])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset = "TaiwanSecuritiesTraderInfo",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader_id | securities_trader | date | address | phone | |
---|---|---|---|---|---|
0 | 1020 | 合庫 | 2011-12-02 | 台北市大安區忠孝東路四段325號2樓(部分)、經紀部複委託科地址:台北市松山區長安東路二段225號5樓 | 02-27528000 |
1 | 1021 | 合庫- 台中 | 2011-12-02 | 台中市西區民權路91號6樓 | 04-22255141 |
2 | 1022 | 合庫-台南 | 2011-12-02 | 台南市北區成功路48號3樓 | 06-2260148 |
3 | 1023 | 合庫-高雄 | 2011-12-02 | 高雄市大勇路97號5樓 | 07-5319755 |
4 | 1024 | 合庫-嘉義 | 2011-12-02 | 嘉義市國華街279號2樓 | 05-2220016 |
{
securities_trader_id: str,
securities_trader: str,
date: str,
address: str,
phone: str
}
台股分點資料表(query by 股票代碼) TaiwanStockTradingDailyReport (只限 sponsor 會員使用)¶
- 提供台股,上市、上櫃、興櫃,的分點資訊!
- 資料區間:2021-06-30 ~ now
- 由於資料量過大,單次請求只提供一天資料
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
- 部分資料缺失,缺失日期為:2022-10-31~2022-11-03, 2023-01-11~2023-01-17
- 開啟 Async 功能,可大幅縮短資料更新時間,colab 實測 2175 檔股票,只需 4 分 20 秒即可完成下載。
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_trading_daily_report(
stock_id="2330",
date='2022-06-16',
)
print(df)
from FinMind.data import DataLoader
from loguru import logger
import datetime
token = ""
data_loader = DataLoader()
data_loader.login_by_token(token)
date = '2024-12-20'
taiwan_stock_price_df = data_loader.taiwan_stock_daily(start_date=date)
# 只拿取當天交易量大於 0 的股票
taiwan_stock_price_df = taiwan_stock_price_df[
["stock_id", "Trading_Volume"]
]
taiwan_stock_price_df = taiwan_stock_price_df[
taiwan_stock_price_df["Trading_Volume"] > 0
]
# 拿取當天上市櫃,industry_category 非大盤, index, 所有證券的股票 ID
# 因為這些股票沒有分點
stock_info_df = data_loader.taiwan_stock_info()
stock_info = stock_info_df[stock_info_df["type"].isin(["twse", "tpex"])]
cate_mask = stock_info["industry_category"].isin(
["大盤", "Index", "所有證券"]
)
id_mask = stock_info["stock_id"].isin(["TAIEX", "TPEx"])
stock_info = stock_info[~(cate_mask | id_mask)]
stock_info = stock_info.merge(
taiwan_stock_price_df, how="inner", on=["stock_id"]
)
stock_info = stock_info[~stock_info["stock_id"].isin(taiwan_stock_price_df)]
stock_id_list = list(set(stock_info["stock_id"].values))
logger.info(f"len: {len(stock_id_list)}") # 2175
start = datetime.datetime.now()
df = data_loader.taiwan_stock_trading_daily_report(
stock_id_list=stock_id_list,
date=date,
use_async=True,
)
cost = datetime.datetime.now() - start
logger.info(cost)
# 0:04:20.405935
import requests
import pandas as pd
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report'
parameter = {
"data_id": "2330",
"date": "2022-06-16",
"token": token, # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report'
response = httr::GET(
url = url,
query = list(
data_id="2330",
start_date= "2022-06-16",
token = token # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader | price | buy | sell | securities_trader_id | stock_id | date | |
---|---|---|---|---|---|---|---|
0 | 合庫 | 508 | 4000 | 2000 | 1020 | 2330 | 2022-06-16 |
1 | 合庫 | 509 | 3480 | 0 | 1020 | 2330 | 2022-06-16 |
2 | 合庫 | 510 | 2310 | 50 | 1020 | 2330 | 2022-06-16 |
3 | 合庫 | 511 | 1169 | 0 | 1020 | 2330 | 2022-06-16 |
4 | 合庫 | 512 | 1300 | 10000 | 1020 | 2330 | 2022-06-16 |
{
securities_trader: str,
price: float64,
buy: int32,
sell: int32,
securities_trader_id: str,
stock_id: str,
date: str
}
台股分點資料表(query by 券商代碼) TaiwanStockTradingDailyReport (只限 sponsor 會員使用)¶
- 提供台股,上市、上櫃、興櫃,的分點資訊!
- 資料區間:2021-06-30 ~ now
- 由於資料量過大,單次請求只提供一天資料
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
- 部分資料缺失,缺失日期為:2022-10-31~2022-11-03, 2023-01-11~2023-01-17
Example
import requests
import pandas as pd
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report'
parameter = {
"securities_trader_id": "1020",
"date": "2022-06-16",
"token": token, # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report'
response = httr::GET(
url = url,
query = list(
securities_trader_id="1020",
start_date= "2022-06-16",
token = token # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader | price | buy | sell | securities_trader_id | stock_id | date | |
---|---|---|---|---|---|---|---|
0 | 合庫 | 122.25 | 19000 | 0 | 1020 | 0050 | 2022-06-16 |
1 | 合庫 | 122.3 | 80000 | 0 | 1020 | 0050 | 2022-06-16 |
2 | 合庫 | 122.35 | 10000 | 0 | 1020 | 0050 | 2022-06-16 |
3 | 合庫 | 122.5 | 1300 | 0 | 1020 | 0050 | 2022-06-16 |
4 | 合庫 | 122.55 | 20000 | 0 | 1020 | 0050 | 2022-06-16 |
... | ... | ... | ... | ... | ... | ... | ... |
3211 | 合庫 | 107 | 1000 | 50000 | 1020 | 9958 | 2022-06-16 |
3212 | 合庫 | 107.5 | 0 | 32000 | 1020 | 9958 | 2022-06-16 |
3213 | 合庫 | 108 | 0 | 2000 | 1020 | 9958 | 2022-06-16 |
3214 | 合庫 | 108.5 | 150 | 0 | 1020 | 9958 | 2022-06-16 |
3215 | 合庫 | 16.05 | 1000 | 0 | 1020 | 9962 | 2022-06-16 |
{
securities_trader: str,
price: float64,
buy: int32,
sell: int32,
securities_trader_id: str,
stock_id: str,
date: str
}
台股權證分點資料表(query by 股票代碼) TaiwanStockWarrantTradingDailyReport (只限 sponsor 會員使用)¶
- 資料區間:2023-06-21 ~ now
- 由於資料量過大,單次請求只提供一天資料
- 資料更新時間 星期一至五 01:00,實際更新時間以 API 資料為主
Example
import requests
import pandas as pd
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_warrant_trading_daily_report'
parameter = {
"data_id": "084655",
"date": "2023-06-21",
"token": token, # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_warrant_trading_daily_report'
response = httr::GET(
url = url,
query = list(
data_id="084655",
start_date= "2023-06-21",
token = token # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader | price | buy | sell | securities_trader_id | stock_id | date | |
---|---|---|---|---|---|---|---|
0 | 元富 | 2.48 | 0 | 4000 | 5920 | 084655 | 2023-06-21 |
1 | 凱基 | 2.48 | 4000 | 0 | 9200 | 084655 | 2023-06-21 |
{
securities_trader: str,
price: float64,
buy: int32,
sell: int32,
securities_trader_id: str,
stock_id: str,
date: str
}
台股權證分點資料表(query by 券商代碼) TaiwanStockWarrantTradingDailyReport (只限 sponsor 會員使用)¶
- 資料區間:2023-06-21 ~ now
- 由於資料量過大,單次請求只提供一天資料)
- 資料更新時間 星期一至五 23:00,實際更新時間以 API 資料為主
Example
import requests
import pandas as pd
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_warrant_trading_daily_report'
parameter = {
"securities_trader_id": "5920",
"date": "2023-06-21",
"token": token, # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_warrant_trading_daily_report'
response = httr::GET(
url = url,
query = list(
securities_trader_id="5920",
start_date= "2023-06-21",
token = token # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader | price | buy | sell | securities_trader_id | stock_id | date | |
---|---|---|---|---|---|---|---|
0 | 元富 | 0.97 | 50000 | 0 | 5920 | 07741U | 2023-06-21 |
1 | 元富 | 0.98 | 50000 | 0 | 5920 | 07741U | 2023-06-21 |
2 | 元富 | 1.52 | 100000 | 0 | 5920 | 07742U | 2023-06-21 |
3 | 元富 | 1.56 | 49000 | 0 | 5920 | 07742U | 2023-06-21 |
{
securities_trader: str,
price: float64,
buy: int32,
sell: int32,
securities_trader_id: str,
stock_id: str,
date: str
}
台股八大行庫買賣表 TaiwanStockGovernmentBankBuySell (只限 sponsor 會員使用)¶
- 資料區間:2021-06-30 ~ now
- 由於資料量過大,單次請求只提供一天資料
- 資料更新時間 星期一至五 23:30,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_government_bank_buy_sell(
start_date='2023-01-17',
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanStockGovernmentBankBuySell",
"start_date": "2023-01-17",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanStockGovernmentBankBuySell",
start_date= "2023-01-17",
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | stock_id | buy_amount | sell_amount | buy | sell | bank_name | |
---|---|---|---|---|---|---|---|
0 | 2023-01-17 | 0050 | 43992298.6 | 53309904.25 | 372595 | 451744 | 兆豐 |
1 | 2023-01-17 | 5202 | 288.0 | 303.50 | 20 | 20 | 第一 |
2 | 2023-01-17 | 5202 | 0.0 | 59.45 | 0 | 4 | 華南 |
3 | 2023-01-17 | 5203 | 82800.0 | 0.00 | 1000 | 0 | 兆豐 |
4 | 2023-01-17 | 5203 | 249000.0 | 583600.00 | 3000 | 7000 | 臺銀 |
{
date: str,
stock_id: str,
buy_amount: float64,
sell_amount: float64,
buy: int64,
sell: int64,
bank_name: str
}
台灣大盤融資維持率 TaiwanTotalExchangeMarginMaintenance (只限 backer、sponsor 會員使用)¶
- 資料區間:2001-01-05 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_total_exchange_margin_maintenance(
start_date='2024-04-01',
end_date='2024-05-01'
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/data"
parameter = {
"dataset": "TaiwanTotalExchangeMarginMaintenance",
"start_date": "2020-04-01",
"end_date": "2020-05-01",
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/data'
response = httr::GET(
url = url,
query = list(
dataset="TaiwanTotalExchangeMarginMaintenance",
start_date= "2024-04-01",
end_date='2024-05-01'
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
date | TotalExchangeMarginMaintenance | |
---|---|---|
0 | 2024-04-01 | 166.007 |
1 | 2024-04-02 | 167.079 |
2 | 2024-04-03 | 167.085 |
3 | 2024-04-08 | 167.119 |
4 | 2024-04-09 | 167.095 |
{
date: str,
TotalExchangeMarginMaintenance: float64
}
當日卷商分點統計表 TaiwanStockTradingDailyReportSecIdAgg (只限 sponsor 會員使用)¶
- 提供台股,上市、上櫃、興櫃,的分點資訊!
- 資料區間:2021-06-30 ~ now
- 資料更新時間 星期一至五 21:00,實際更新時間以 API 資料為主
Example
from FinMind.data import DataLoader
api = DataLoader()
# api.login_by_token(api_token='token')
# api.login(user_id='user_id',password='password')
df = api.taiwan_stock_trading_daily_report_secid_agg(
stock_id="2330",
securities_trader_id="1020",
start_date= "2024-07-01",
end_date="2024-07-15",
)
import requests
import pandas as pd
url = "https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report_secid_agg"
parameter = {
"data_id": "2330",
"securities_trader_id": "1020",
"start_date": "2024-07-01",
"end_date": '2024-07-15',
"token": "", # 參考登入,獲取金鑰
}
data = requests.get(url, params=parameter)
data = data.json()
data = pd.DataFrame(data['data'])
print(data.head())
library(httr)
library(data.table)
library(dplyr)
url = 'https://api.finmindtrade.com/api/v4/taiwan_stock_trading_daily_report_secid_agg'
response = httr::GET(
url = url,
query = list(
data_id="2330",
securities_trader_id="1020",
start_date= "2024-07-01",
end_date='2024-07-15',
token = "" # 參考登入,獲取金鑰
)
)
data = content(response)
df = data$data %>%
do.call('rbind',.) %>%
data.table
head(df)
Output
securities_trader | securities_trader_id | stock_id | date | buy_volume | sell_volume | buy_price | sell_price | |
---|---|---|---|---|---|---|---|---|
0 | 合庫 | 1020 | 2330 | 2024-07-01 | 12157 | 12460 | 968.08 | 973.84 |
0 | 合庫 | 1020 | 2330 | 2024-07-02 | 12735 | 21885 | 964.54 | 964.63 |
0 | 合庫 | 1020 | 2330 | 2024-07-03 | 10535 | 29381 | 973.16 | 974.69 |
0 | 合庫 | 1020 | 2330 | 2024-07-04 | 28107 | 59459 | 1001.99 | 1000.88 |
0 | 合庫 | 1020 | 2330 | 2024-07-05 | 10435 | 11075 | 1004.18 | 1004.5 |
{
securities_trader: str,
securities_trader_id: str,
stock_id: str,
date: str,
buy_volume: int64,
sell_volume: int64,
buy_price: float,
sell_price: float,
}