更新日誌
2.0.4 (2026-05-01)
Fix
backtest/sim.py:_prefetch_market_datasets()從_prepare_simulation_inputs抽出,改在sim()進入_backtest_context()之前呼叫。此前 prefetch 與後續資料載入都在prefer_local_if_exists=True的 context 內執行,data.gets()會跳過 expiry 檢查與.recent合併,導致 session 啟動時若本地某個 sim_dataset(例如etl:adj_close)的 pickle 還未刷新,sim 會靜默使用 stale cache,使report.creturn.index[-1]比 user code 的data.get('price:收盤價').index[-1]早收(典型症狀:creturn 在某個未來 dataset 的最後更新日期截斷)。把 prefetch 提到 context 之外後,sim_datasets()列出的所有 dataset 在進入 backtest cache 鎖定區之前就會走完正常的 expiry / recent 合併流程
2.0.3 (2026-04-28)
Performance
data.gets(): 將過期快取走.recent合併的迴圈從序列改為ThreadPoolExecutor平行(最多 8 條),4 個 dataset 全部 stale 的情境在 200ms RTT 下從 ~1030ms 收斂至 ~420ms(2.4× 加速)data/auth.py、data/get.py:下載路徑統一為「單次 GET → 預先配置bytearray(content_length)+memoryview切片寫入 →feather.read_feather(pa.py_buffer(raw))zero-copy 解析 →set_dataframe_bytesverbatim 落地」,省掉舊路徑的 stream-to-disk per-chunk callback、feather metadata 驗證 read 與 pandas re-encoding。Chunk size 從 64 KiB 提高為 1 MiB,100 MB 下載的 progress callback 次數從 ~1600 次降至 ~100 次。本機 micro-benchmark 在小、中、並行情境一致觀察到 1.21–1.28× 加速
Refactor
data/get.py:移除_download_persist_file_storage_misses、_download_file_storage_misses_to_storage、_download_persist_one_file_storage_miss、_validate_feather_file與_materialize_full_misses中的isinstance(target_storage, FileStorage)分岔,FileStorage 與 CacheStorage 共用一條_download_full_miss_frames→_persist_full_miss_frames路徑data/get.py:抽出_run_parallel_tasks(keys, worker)generator,_resolve_recent_candidates與_download_full_miss_frames_threaded共用同一個min(8, n)ThreadPoolExecutor +as_completedpattern;單檔情境會自動 fallback 為 in-thread 執行data/auth.py:刪除_download_ipc_file,新增_download_feather_bytes(streaming 加 progress 都集中在這),_download_dataframe改回傳(df, raw_bytes)data/storage.py:新增FileStorage.set_dataframe_bytes(name, payload, expiry),把 raw feather bytes 原樣寫到.feather,省掉df.to_feather的重新編碼成本;移除set_feather_file、set_feather_bytes與_atomic_file_replace用不到的validate_fn參數,set_dataframe與set_dataframe_bytes共用_persist_featherhelper- 整體淨減 213 行,162 個相關測試保持綠燈
2.0.2 (2026-04-28)
Changed
markets/tw.py:TWMarket.sim_datasets()預取清單加回 5 個 TW 必載資料表(benchmark_return:發行量加權股價報酬指數、security_categories、price:成交股數、etl:is_flagged_stock、etl:market_value),改以單次批次請求取代 sim 過程中分批的 on-demand fetch;此舉部分回退 2.0.1 為了降低 peak RSS 而拆分的 on-demand 設計,記憶體會略增但換來更穩定的批次配額表現finlab/core: 重新打包everything.js與style.cssweb component dashboard assets
Fix
finlab/core: dashboard iframe height 改用requestAnimationFrame節流並比較getBoundingClientRect()高度,避免ResizeObserver與scrollHeight在某些佈局下互相觸發造成的尺寸抖動
2.0.1 (2026-04-26)
Performance
backtest: 大幅降低sim()的峰值記憶體用量。以使用者量測的簡單月頻全市場策略為例,sim(..., resample="M", upload=False)的 peak RSS 從 ~2.0–2.2 GiB 下降至約 1.29 GiB(約省 800 MB),讓原本 OOM 的 s-tier 雲端 worker 可以順利完成回測:markets/tw.py:TWMarket.sim_datasets()改為依trade_at_price與touched_exit回傳所需的 adjusted OHLC 子集,並移除原本硬編碼的 9 個資料表(移除price:收盤價、price:成交股數、benchmark_return、etl:is_flagged_stock、etl:financial_statements_disclosure_dates,這些現在由呼叫端按需 fetch)backtest/sim.py:_prefetch_market_datasets以inspect.signature偵測第三方Market子類的sim_datasets簽名,向下相容 pre-kwarg 的 zero-arg 版本dataframe/core.py:is_largest/is_smallest以np.argpartition取代np.argsort,省去filled中介矩陣;rank(axis=1)不再配置filled副本,改為就地 negation + 重用arr作為 ranks buffer(peak allocations 從 ~3.1× 降到 ~2.4× 輸入 frame)backtest/report.py: 新增_prefilter_for_trade_dates工具函式,_attach_trade_prices在呼叫add_trade_info前先將trade_price/adj_close縮到僅含交易日期的 slim 版本,使 Cython 端的 reindex 變成 no-op(少掉 ~2× frame-sized 的 transient copy)analysis/liquidityAnalysis.py:calculate_trade_info先 slimadj_trade_price/trade_price/volume再做pct_change = adj_trade / adj_prev - 1與turnover = trade_price * volume;以_previous_trading_day_slice取代close.shift()的全表副本,使 Liquidity 對 peak RSS 的貢獻從 ~512 MB 降到 ~306 MB
Features
cli: 新增python -m finlab cloud指令群,支援將策略部署至雲端並設定每日自動執行(Asia/Taipei 時區)。可透過finlab-auto-updateCloud Functions 管理策略生命週期:cloud deploy <sid>— 上傳策略(支援--code單檔.py或--zip多檔壓縮,zip 需搭配--entry-script),可同時指定--time HH:MM排程、--tier {s,m,l,xl}運算資源,以及--contest/--no-contest/--contest-alias參賽設定cloud get <sid>— 查看策略中繼資料、參賽狀態與 inline 原始碼,--code-only可僅輸出程式碼便於導向檔案cloud list— 列出所有已部署策略(SID、tier、排程、類型、參賽狀態),--limit最多 500 筆cloud run <sid>— 手動觸發一次執行(每小時每策略限 5 次),--tier可覆寫本次資源cloud logs <sid>— 查看最近執行紀錄(狀態、耗時、費用、排入時間),--show-output附上 stdout/stderrcloud schedule set/delete— 單獨調整或移除策略的每日排程cloud delete <sid>— 刪除策略與排程(執行歷史保留),-y略過確認cloud status— 顯示當月預算、已用額度、剩餘額度、可用 tier 與執行次數統計,--month YYYY-MM可查詢指定月份finlab/core: 更新 web component dashboard assetsfinlab/core: 改為直接納入主 repo,不再以finlab_coresubmodule 取得 Cython core 與 dashboard assets
Refactor
cli: 移除本機 broker、notebook、schedule、workspace 等舊 CLI 模組,改以輕量 HTTP client 呼叫 Cloud Functions,同時移除nbformat與rich_click依賴
Docs
cli: 更新docs/cli.md與docs/cli.en.md,移除已刪除的舊 CLI 指令(init、auth、broker、nb、pm、schedule),改為只記錄目前支援的python -m finlab登入、憑證、遷移與雲端策略流程
Fix
online:Position於 stop event 後不再提前套用下一期next_weights,改以next_weights.name對應的 market close 時間判斷切換時機,避免在盤中就以未來部位建倉
2.0.0 (2026-04-22)
Engineering
exceptions: 新增finlab.exceptions模組,定義結構化例外階層(FinlabError、DataError、BacktestError、BrokerError、AuthError、PortfolioError、ConfigError)backtest: 將 500 行的sim()函式重構為 5 個可獨立測試的階段函式(_validate_sim_inputs、_prepare_price_data、_normalize_position、_execute_simulation、_build_sim_report),以_NormalizedPosition與_SimulationResultdataclass 傳遞階段間資料data: 新增DataContext類別,將 13 個模組層級全域變數封裝為單一物件,支援override()context manager 安全地暫時覆蓋狀態,為未來並行策略執行奠定基礎optimize: 移除combinations.py中的eval()呼叫,改用基於 AST 的安全條件解析器,杜絕任意程式碼執行風險exceptions: 將 20 個檔案中 47 處except Exception收窄為具體例外型別(requests.RequestException、OSError、KeyError等),提升交易系統的錯誤可觀測性ci: 新增pytest-cov覆蓋率門檻(fail_under=50),於 CI 中強制執行,排除 vendored/submodule 程式碼ruff: 重新啟用BLE001(blind except)與C901(mccabe complexity)lint 規則,以 per-file-ignores 管理尚待重構的複雜函式
Features
data:data.gets()新增 pip 風格的即時下載進度顯示,支援平行下載時多列同步更新。自動偵測環境:終端機顯示 ANSI 彩色進度條(含速度與大小),Jupyter Notebook 顯示 HTML 進度條。CJK 字元寬度對齊正確,零額外依賴dataframe:df.sectoraccessor 新增 7 個產業內聚合方法:mean()— 產業內平均值std(ddof)— 產業內標準差median()— 產業內中位數sum()— 產業內總和min()— 產業內最小值max()— 產業內最大值count()— 產業內有效值數量dataframe: 新增df.weightaccessor,提供投資組合權重建構方法:cap_industry(max_weight)— 限制每個產業的最大權重,超額按比例重新分配clip_by_volume(total_fund, max_participation_ratio)— 依日均成交金額限制個股權重inverse_volatility(window)— 反波動率加權,低波動股票獲得較高權重risk_parity(window)— 風險平價加權,使每個持股的風險貢獻相等correlation(diversify)— 依相關性調整權重,分散化或集中化target_volatility(target, window)— 縮放權重以達成目標年化波動率limit_turnover(max_turnover)— 限制相鄰換倉的雙向換手率drawdown_control(max_drawdown)— 回撤超過門檻時自動縮減曝險dataframe: 新增df.csaccessor,提供跨股票(cross-sectional)資料轉換:rank()— 百分位排名winsorize(lower, upper)— 百分位縮尾處理bucket(n)— 等分位分組zscore()— 標準化demean()— 去均值dataframe: 新增df.sectoraccessor,提供產業內資料轉換(與df.cs相同的 5 個方法,但在同產業內計算)online: 新增PositionStreamMixin即時持倉串流功能:- 混合模式:以
get_position()初始化,透過 Fill 事件即時更新,定期輪詢對帳(預設 30 秒) - 新增
PositionUpdatedataclass,含snapshot_key()去重機制 RealtimeProvider自動繼承subscribe_positions()/on_position()介面
Refactor
dataframe: 將FinlabDataFrame重構為 package(finlab/dataframe/),包含core.py、weight.py、cs.py、sector.py,既有 import 路徑不受影響dataframe: 新增from finlab import FinlabDataFrame頂層匯出dataframe: 提取_get_column_categories()為共用 helper,消除groupby_category與產業權重方法之間的重複邏輯
Fix
analysis: 修正calc_shapley_values與calc_factor_return因使用 Pythonnot對 pandas boolean Series 取反而必定拋出ValueError的問題,改為正確的 element-wise~運算子 (#71)
Docs
market: 修正文件中不存在的 dataset 名稱etl:us_adj_close,改為正確的us_price:adj_close(#68)
Tests
- 新增 68 個測試,涵蓋所有新增的 weight / cs / sector 方法
- 新增
calc_factor_return與calc_shapley_values的單元測試,驗證 mask 運算與輸入驗證
1.5.13 (2026-03-22)
Features
data:universe()、us_universe()、set_universe()、set_us_universe()新增index參數,支援以市場指數(S&P 500、NASDAQ 100)篩選美股成分股。可與sector、industry、exchange組合使用 (#55, #57)market: 新增台灣可轉債市場(TW CB Market),並於finlab_core的to_html支援可轉債顯示 (#64,399e789)
Fix
storage: 修正_check_and_apply_reset_time在多個 Python process 中重複檢查 server reset time 的問題。以 marker 檔記錄已套用的 reset timestamp 與 expiry.pkl mtime,跨 process 共用,避免重複 reset。同時修正save_expiry()失敗時仍寫入 marker 導致後續永遠跳過 reset 的 bug (34c5055)analysis: 修正MaeMfeAnalysis.calc_edge_ratio()在 US market 回測時因entry_price為零導致ZeroDivisionError的問題,同時消除display()中重複的 edge ratio 計算邏輯 (#45, #66)compat: 將 pandas 已棄用的 resample aliases('M'、'Y'、'A')統一替換為'ME'/'YE'(pandas ≥ 2.2),集中至finlab.compat.MONTHLY_END/YEARLY_END常數,並修正原先使用字串比較版本號的 bug (#63)portfolio: 修正PortfolioSyncManager.from_cloud()/to_cloud()在 Firebase auth 時使用錯誤的 token 參數名稱(硬編碼api_token而非使用token_type),同時修正notebook.py傳入 tuple 而非 string 的問題 (#52)hold_until: 修正 pandas 3.0 Copy-on-Write 模式下hold_until()觸發ValueError的問題 (#67)report: 修正position2未填入交易資料與entryAdjPrice計算錯誤的問題 (d89f782)report: 修正 cloud report round-trip 中"hold"action 未正規化的問題,同時自動重建過期 Cython 模組 (c476cba)report: 修正CloudReport.__init__中updated_at未正確 propagate 至positionConfig.created的問題 (26eb765)online: 更新 submodule,修正 dashboard API calls 未正確路由token_type的問題 (87ecf68)data: 修正IndicatorName.decode在無參數 indicator 時尾部多餘分隔符號的問題 (87e3c80)data: 修正big_investments()執行後未重設 universe,導致後續策略 column mismatch 的問題 (0c84806)compat: 修正_pd_versionparser 無法解析 pandas prerelease 版本號的問題 (5399d97)
Refactor
deprecation: 改善 deprecation warnings,改為只顯示一次,並抽出 deadline 常數、去重 auth imports (b7f6072)
Docs
backtest: 更新sim()docstrings,修正 batch order 範例中 progress 計算邏輯 (#56)portfolio: 移除文件中不存在的create_report()與get_returns()方法,改用正確 API (#51)
Tests
- 修正 14 個測試失敗,涵蓋 auth、projection、E2E suites (
a194ea1)
Chore
- 升級 Docker base image 至 Python 3.12 並更新相關依賴 (
66a44df) - 新增
twine至 dev dependencies (28bb8eb)
1.5.12 (2026-03-17)
Fix
data: 修正data.get()在長時間 session(如 Google Colab)中,已載入的 dataset 即使 cache 過期仍回傳舊資料不更新的問題。原因是_loaded_datasets完全跳過 expiry 檢查,改為仍檢查本地 expiry 時間,過期時正常觸發 merge/download 流程online: 修正 Sinopac broker 將所有股票合約硬編碼為 TSE 交易所,導致 OTC 股票即時報價訂閱與 tick backfill 失敗的問題。改為透過 snapshot API 動態偵測 TSE/OTC 並快取結果 (e21f7fc)
1.5.11 (2026-03-11)
Features
report: 將 report payload 遷移至 canonical Firestore 流程(users/{uid}/reports/{sid}),搭配 cloud function projection 產出 legacy docs (4719592)data: 新增data.get_role()與data.is_vip()查詢使用者角色 (e282344)schemas: 新增finlab.schemas正式資料結構(dataclass + TypedDict)並補齊覆蓋率 (ae953cd)online: 完成 typed order output migration (0b16f26)portfolio: 完成 typed portfolio data access (337c2df)typed-boundary: 完成 strict mode typed boundary gates (65cae23)data: 在未過期資料情境下,市場交易時段is_tradable會回傳 true (121e2ac)
Refactor
symbol: 完成 shared symbol resolution cleanup (a9bf1c2)symbol: 內部統一使用symbol作為 canonical identifier (6b816b2)schemas: schema dataclass 改為 symbol-only (ac592cf)
Fix
backtest: 修正sim()上傳策略時使用 daemon thread,導致腳本結束時上傳被中斷的問題 (9b0b4c5)data:is_tradable()在無 expiry 資料時改回傳False(保守策略:無法驗證資料新鮮度則不交易)(9b0b4c5)data:is_tradable與next_future_expiry改為只檢查當次 session 已載入的 datasets (b16eda4)report: 修正 report projection legacy parity(daily_mean、return_table、drawdown_details、trail_stop等欄位)(83a4e33,dea8afa)report: 移除 Firestore legacy docs 中的 time-series 陣列,避免超過 40K index 上限 (9af94d9)report: 修正 market-close timestamps 的時區正規化 (91ba4dc)report: 保持 cloud report schedulers 與 execution 同步 (11ef166)report: 收緊 cloud report migration validation (297de5e)storage: file storage 寫入改為跨程序 atomic (8436ab8)analysis: 修正LiquidityAnalysis修改report.trades導致間歇性KeyError的問題 (a14d9fb)docs: 修正 i18n alternate links 與 redirect Location headers (784e4a1,e58b085)tests: 穩定 non-real-order 測試流程與 optional model discovery (731ed8e)
Tests
- 新增 E2E parity test,驗證 report projection 產出的 legacy docs 與舊
write_database完全一致 (5d893a3) - 收緊 E2E parity test:比較 stats、trades、所有 position 欄位及 strategy summary (
f2e5929,d702a84) - 新增 firebase admin report migration 測試覆蓋 (
7358a45) - 新增 market close timestamp normalization 測試 (
d747ccc) - 修正
test_data_freshness測試與 scoped expiry 行為對齊 (9b0b4c5) schemas: 新增 schema specs 與 TDD coverage workflow (ccf3e54)guardrail: 新增測試,涵蓋 dual keys 與 config shape (ce318b2)position: 完成 typed APIs 的 TDD cycle (cfe5d97)online: 新增 order executor typed output 測試 (0a866f3)portfolio: 新增 typed data APIs 測試 (2c4ea06)symbol: 新增 shared symbol resolver 測試 (19f6f22)strict-mode: 新增 typed strict mode 測試 (d6780dc)data: 隔離 data freshness 測試與 loaded dataset global state (fbedb2c)
Docs
- 新增 typed data migration guide 與 deprecation policy (
fb341d5) - 完成 migration runbook 的 definition of done (
e0af883)
Chore
online: 更新 submodule,所有 broker 新增Stock.pct_change(94032d5)- 合併
dataclass-migration-tdd分支 (dd670e5)
1.5.9
Refactor
analysis: 移除Report子類別(~270 行),to_text()與to_terminal()改由finlab_core的Report類別直接提供,from finlab.analysis import Report仍可使用 (#43)
Features
data: 新增 80% 配額使用量警告,在data.get()中於配額耗盡前提前通知使用者 (#40)schemas: 新增finlab.schemas,提供PositionEntry/OrderEntry/PortfolioData等正式資料結構(dataclass + TypedDict)online:OrderExecutor.generate_orders()新增as_entries與quantity_type,並提供generate_order_entries()typed 介面portfolio:PortfolioSyncManager新增get_data()/set_data()與get_data_typed()/set_data_typed()typed 存取介面
Fix
dataframe: 修正 Windows 環境下FinlabDataFrame.__setattr__路徑比對失敗,導致內部set_index被誤擋的問題backtest:sim()使用市場專屬的預設fee_ratio和tax_ratio,不再使用固定預設值 (#38)market:get_market_by_name()支援市場短代碼 fallback(MARKET_CODE_TO_CLASS)(#37)analysis: 修正 K 線圖在 Firestore API 請求失敗時無限轉圈的問題,改為顯示錯誤訊息與重試按鈕 (#23)
Docs
- 移除尚未開源的 git clone 安裝教學 (#27)
- 改善
Market.get_price()文件,補充完整參數說明、必須實作的值與實作範例 (#26) - 新增 typed data migration 指南與
symbol/stock_iddeprecation policy 說明(docs/details/typed_data_interfaces.md)
Chore
- 新增 Claude Code GitHub Actions 工作流程 (#25)
1.5.8
Features
verify: 新增verify_strategy()前視偏差(lookahead bias)自動檢測工具dataframe: 禁止直接覆寫FinlabDataFrame.index,防止 lookahead biasdataframe:rank()新增valid參數,支援有效值篩選data: 新增next_future_expiry()自動跳過到期資料data: 新增資料新鮮度檢查(data freshness check),確保交易前資料為最新terminal: 新增report.to_terminal()終端機圖表工具,無需 Jupyter 即可檢視回測結果auth: 改為 Firebase 瀏覽器登入,支援自動命名 session、環境變數認證、FINLAB_API_TOKEN遷移提示compat:stock_id→symbol全面遷移,stock_id仍可向後相容使用pyodide:report.upload()在 Pyodide 環境中改為同步執行
Performance
- 整體策略執行速度提升 3.4x(12.9s → 3.8s,含資料讀取、訊號計算、回測)
| 步驟 | 優化前 | 優化後 | 加速 |
|---|---|---|---|
data.get (4 calls) |
0.40s | 0.00s | ∞ |
vol.average(20) |
0.69s | 0.62s | 1.1x |
pb.rank() |
1.57s | 1.04s | 1.5x |
rev.rank() |
1.49s | 0.50s | 3.0x |
is_smallest(10) |
5.25s | 0.40s | 13.3x |
sim() |
3.30s | 1.08s | 3.1x |
dataframe:is_largest/is_smallest改用 numpyargsort(kind='stable')取代 pandasapply(nlargest/nsmallest),保留欄位順序一致的 tie-breaking(13.3x)dataframe:rank(axis=1)改用 numpyargsort快速路徑,並在index_str_to_date()展開前先排名,避免季資料(51 列)展開為日資料(2110 列)後才排名(3.0x)dataframe:reshape()新增快速路徑,當兩個 DataFrame 的 index/columns 已相同時跳過 reindexbacktest:sim()內部使用prefer_local_if_exists避免重複檢查雲端過期時間backtest: position normalization 改用 numpy 陣列運算取代 pandas.div().fillna()backtest:upload改為 daemon thread 非同步執行,不阻塞回測結果回傳backtest: 快取TWMarket._categories_cache避免重複呼叫data.get('security_categories')data: 新增_finalized_cache,快取data.get()處理後的結果,重複呼叫時跳過process_data轉換data: 先檢查過期時間再讀取 DataFrame,避免不必要的磁碟 I/Odata:FileStorage.get_dataframe()在記憶體快取命中時跳過os.path.getmtime系統呼叫
Fix
backtest: 修正touched_exit跳空開盤觸發停利/停損時,持倉價值被多乘cr_old導致creturn偏高的 bug。當開盤價直接超過停利(或停損)價位時,touch_open路徑的公式pos *= open_r / r與touch_high/touch_low不一致,已修正為pos = entry_pos * open_rbacktest: 修正pdays(獲利天數)計算的浮動問題analysis: 修正AlphaBetaAnalysis缺少display()方法,導致run_analysis('AlphaBetaAnalysis')無輸出dataframe: 修正 Pandas 2.0+ Copy-on-Write 環境下hold_until的相容性問題dataframe: 修正is_largest/is_smallest在遇到pd.NA時的轉換錯誤dataframe:industry_rank中eval()改為ast.literal_eval()修正安全性問題data: 修正truncate_end季度財報截斷邏輯,改用揭露日遮罩,避免誤刪已揭露資料data: 修正_finalized_cache未將universe和truncate納入快取 key 的問題data: 修正_get_expiry_dict未篩選已載入資料集的問題storage: 修正多 process 共用時 mtime 快取驗證遺失的問題portfolio: 修正策略權重為零時 Portfolio 不一致的問題portfolio: 修正 close-strategy 在歷史資料為空時,持倉被誤賣於 open sync 的問題auth: 修正 token refresh 失敗時不必要開啟瀏覽器登入的問題auth: 修正login()未先檢查快取 token 的問題auth: 改用穩定的 machine ID 取代不可靠的uuid.getnode()auth: 支援id_token於回測上傳與雲端資料請求sim: 修正 pandas 3.0 下以 DataFrame 作為trade_at_price的相容性問題
Docs
- 新增
neutralize/neutralize_industry教學文件 - 新增完整 API 參考文件與文件架構強化
- 新增 FinLab AI Skill (finlab.finance) 介紹
- 修正文件中停利與移動停利參數名稱錯誤
- 修正
trade_at_price='close'被誤標為未來函數的說明 - 修正 ML 策略流程文件使用不存在的 API
1.5.7 (2026-01-28)
Features
data: 改進data.search()函數,使用 Firestore API 並簡化輸出格式為 list,回傳可直接用於data.get()的字串列表data: 支援美股資料搜尋 (US catalog)
Refactor
data: 改進資料擷取和儲存模組,提取共用函數以提高可讀性
Fix
backtest: 修正 pandas 3.0 ArrowStringArray 相容性問題,確保 DataFrame columns 正確轉換為 numpy arraydata: 縮小indicator()的例外處理範圍,避免無效指標名稱產生誤導的 TA-Lib 安裝訊息data: 修正資料目錄中的重複項目tests: 修正calc_regression_stats測試的隨機性問題,添加固定種子確保測試穩定
Chore
- 停止支援 Python 3.8,最低需求為 Python 3.9
1.5.4 (2025-11-21)
Fix
core: 修正Report在is_rebalance_due時,在 resample 為 str 時,產生錯誤。data: 修正FileStorage在get_time_expired時在多個 process 共享時,會出現資料未自動更新的問題
Features
doc: 更精簡的範例文檔
1.5.4 (2025-11-14)
Refactor
data.universe: 重構universe模組
Fix
core: 修正Report在is_rebalance_due時,不間容舊版的問題
1.5.3 (2025-10-03)
Features
dataframe: 實作截斷視窗(truncation window)功能,依據finlab.data設定加速資料擷取
Refactor
data: 重組儲存架構與模組拆分(引入storage.py、調整__init__.py與universe.py),整合截斷流程portfolio: 精簡交易更新流程,資產價值計算納入市場別報價以提高準確性
Fix
data.indicator: 更正adjust_price型別驗證為布林值並強化錯誤訊息label:excess_over_median/mean改用subtract提升運算一致性與可讀性backtest: 改善arguments的重採樣邏輯,統一處理resample_dates與position索引型別
Docs
factor_analysis: 修正變數命名與補充更清晰的範例;更新導覽與教學內容docs: 移除不存在的導航項目並更新範例文檔與 mkdocs 設定
1.5.0 (2025-08-01)
Features
factor_analysis: 新增因子趨勢分析功能,並新增說明簡易範例文檔plot: 新增統一的 plotly 樣式,多種顏色範圍及標記功能,強化線圖的可視化效果,並支援自定義顏色區間plot: 增強plot_line函式,新增進階自定義選項和綜合範例,新增plot_line_example和plot_line_financial_example函式tests: 增加將回測結果序列化為 pickle 格式的功能
Refactor
factor_analysis: 重構函式名稱和參數以提高清晰度,更新文檔以反映變更docs: 更新變更日誌,調整模組結構及命名
Fix
data: 新增use_local_data_only和force_cloud_download功能選項feature: 優化市場配置邏輯,確保在多核環境下正確恢復原始市場設置liquidityAnalysis: 確保交易價格和成交量的形狀一致,並將其轉換為 DataFrame 格式backtest: 修正位置過濾邏輯,確保只保留有效的市場數據並轉換為浮點數doc: 修正 plotly 無法渲染的問題(改用靜態 png)
Docs
- 新增因子擁擠度分析頁面至導航
- 新增簡易教學文檔,更新實用範例教學,讓教學更清楚
- 修改實用範例文檔
- 新增 KaTeX 支援用於數學渲染,並移除過時的因子擁擠度分析
- 新增元富證券設定說明至下單 API 文檔,並移除過時的 PE-PB 圖表圖片
- 修正下單 API 文檔中對元富證券的引用
1.4.0 (2024-05-29)
Features
portfolio: 新增get_total_position方法,以 DataFrame 格式回傳當前持股pyproject: 為開發群組新增shioaji支援
Refactor
backtest: 將Exception替換為ValueError和TypeError以進行更好的錯誤處理market: 將Market類別轉換為抽象基礎類別並更新tw市場
Fix
qlib: 改善缺少finlab[qlib]模組的錯誤處理,提供更詳細的訊息data: 新增use_local_data_only和force_cloud_download功能data: 更新get函式的回傳類型為FinlabDataFramedata: 在__all__中包含額外的匯出pytorch_nn: 移除損壞的 import 並新增ICLoss用於計算資訊係數損失portfolio: 優化移除部位的邏輯並加強更新條件docker: 將finlab版本鎖定在 1.4.0
1.3.0 (2024-05-24)
Features
online: 新增口袋證券 (pocket account) 相關功能fubon: 新增元富證券的下單系統data: 新增財務數據指標的 entry namesdataframe:rank方法新增未來資料窺看警告setup: 新增 Python 3.7 和 3.8 的 classifiersrequirements: 新增Jinja2與ipython套件test: 新增pytest的開發依賴與slow標記- 更新使用 uv 來管理依賴
Refactor
alphalens: 移除alphalens模組與相關功能portfolio: 優化PortfolioSyncManager中移除部位的日誌紀錄backtest: 註解掉設定全域回測報告的未使用程式碼plot: 從plot_test.py移除過時的繪圖測試ml: 改善combine函式中的工廠初始化和型別提示
Fix
setup: 啟用find_namespace_packages支援並改善路徑處理liquidityAnalysis: 修正處置股票的判斷邏輯與漲跌幅評估的日期基準docker: 更新pandas與ta-lib版本backtest: 更新回測上傳訊息ml: 修正combine函式中的變數引用analysis: 修正drawdown的結束日期parallel: 修正ParallelExt以支援較新版本的joblibpyproject: 指定Cython版本以確保相容性
Docs
docs: 重新命名getting-start.md並更新mkdocs.ymlorder_api: 更新憑證取得與套件安裝說明
Type Safety
core: 為FinlabDataFrame和backtest模組新增型別提示
1.2.27 (2025-05-15)
Features
- 新增元富證券的下單系統
finlab.ml.feature.combine支援 dictionary of function 來產生特徵finlab.dataframe.FinlabDataFrame重構rank方法,自動處理財報橫向比較,避免 look ahead 的可能。finlab.dataframe.FinlabDataFrame重構rank方法,警告使用者使用了 look ahead 的可能。
Fix
- qlib 模型引用修正
1.2.24 (2025-05-02)
Features
- 將整個 qlib 的功能整合到 finlab.ml 中,只需要安裝 finlab 就可以使用 qlib 的功能(pip install finlab[qlib])
Refactor
report支援report.to_html(path)將報告轉換成 HTML 檔案report支援report._repr_html_()直接在 Jupyter Notebook 中顯示報告- 將
dashboard移出report模組,獨立成為finlab.core.dashboard模組
Fix
- 修復
report.trades中關於警示股、處置股、全額交割股少部分的資料錯誤 - 修復
report.weights.name以及report.next_weights.name可能為 None 的問題
1.2.23 (2025-03-25)
Fix
- 修正
report.upload在 resample=pd.DatetimeIndex 會報錯的問題
1.2.22 (2025-03-25)
Features
PositionScheduler支援多策略與重新平衡邏輯backtest.sim新增resample=None時自動計算下一個交易日
Fixes
- 更新 macOS 構建架構設定,僅保留
universal2 - 修正
resample參數的邏輯,允許直接使用 - 調整
PositionScheduler.from_report方法以符合新的resample邏輯 - 更新並修正相關的單元測試
1.2.21 (2025-03-12)
Features
report.is_stop_triggered()監測是否有停損停利觸發report.is_rebalance_due()監測是否有再平衡觸發report.to_pickle('PATH')將報告存成 pickle 檔案report.from_pickle('PATH')從 pickle 檔案讀取報告backtest.sim回測速度優化
Fixes
PortfolioSyncManager考慮 weight = 0 的情況data.get在下載異常時,會自動重試backtest.sim針對股票代號異常時,會自動跳過backtest.sim修正做空的報酬率顯示錯誤
1.2.20 (2024-12-09)
Refactor
MarketInfo現在移動至finlab.market模組之中TWMarketInfo現在移動至finlab.markets.tw模組之中,並且改名為TWMarket- fix(market_info): rename loop variable for clarity in shared memory creation
- 使用
finlab.config.set_market來設定全域市場資訊 - 取消
ml.get_market以及ml.set_market,使用finlab.config.set_market代替 - 取消
data.indicator(...market)與finlab.config.set_market合併 - 取消
df.hold_until(...market)與finlab.config.set_market合併
1.2.17 (2024-10-19)
Features
report.weight.name的名稱改成回測最後一天的日期,方便查看,report.next_weight.name的名稱改成換股日期,方便查看,支援 numpy>=2.0然而talib還沒支援,所以需要使用 talib 的話需要再等等。Position支援weight(optional) 的儲存與計算,方便快速比較張數與權重。FugleAccount改成使用 websocket 進行訂單的連線與更新OrderExecutor新增 progress 可以針對「當前部位」與「目標部位」進行內差,方便轉倉平滑過度
Fixes
finlab.online.sinopac處理當股票當天無交易時,避免直接報錯
1.2.16 (2024-10-02)
Fixed
data.get減少非必要的連線次數cli修正 webview 非必要 import 的錯誤finlab.online.sinopac修正get_trades在計算時間時,會將時間轉換成 UTC 時間finlab.portfolio修正PortfolioSyncManager在to_cloud或to_json時,可能會產生不相容的格式
1.2.15 (2024-09-08)
Fixed
position.from_report修正weight.index為非 str 的問題finlab.portfolio修正持有無法交易股票時,會報錯的問題finlab.online修正欲無法交易股票時,會報錯的問題(改成跳出警示)finlab.data修正data.search時搜索數據為空的問題finlab.portfolio修正停損停利時,在某些時刻下會跳過的問題
1.2.12 (2024-8-27)
Features
- dashboard: 新增儀表板中的「與大盤相關性」,並且能夠選擇時間區間
- portfolio: 新增
PortfolioSyncManager的get_position(at='open')的功能,用於規劃當日開盤的部位 - online.position: 優化顯示部位的功能
- online.position: 增加以 for loop 提取部位資訊的功能
- tool.factor_analysis: 增加因子分析功能,除了 IC 以外,支援
get_metric來運算因子的各種指標 - portfolio: 新增
PortfolioSyncManager自動判斷smooth_transition的時機,在初始化時不需平滑過度,於之後都使用平滑過度 - doc: 優化
portfolio下單的教學文件 - sinopac: 永豐證券支援
get_trades功能用於比對帳戶交易紀錄
Fixed
- data: 修正
data.get會於少數作業系統產生 circular import 的問題 - cli: 修正
finlab nb指令會產生import webview的問題
1.2.11 (2024-8-19)
Fixed
- backtest: 修正停損停利時,在少數情況會用到未來資料的問題
- test: 測試回測系統時,使用歷史資料
- report: 修正回測報告中的產業別顯示錯誤
- online: 修正下單時,顯示過多小數點的問題
- schedule: 修正執行策略時,使用到錯誤 Token 的問題
- portfolio.cloud_report: 修正支援 int 型態的 return (在少數情況下會用到)
- backtest: 回測 in-sample 時,將 out-sample 的資料隱藏
- data: 當下載超過 5 分鐘時,會自動終止並且顯示錯誤訊息
1.2.9 (2024-8-3)
Feature
- 新增
finlab.portfolio的PortfolioSyncManager.update使用custom_position來設定股票張數 - 新增
finlab.portfolio的PortfolioSyncManager.update使用excluded_stock_ids來設定忽略的股票
1.2.8 (2024-8-1)
Fix
- 修正在某些狀況下,回測報錯的問題
1.2.7 (2024-8-1)
Fix
- 股票結算於非收盤價,導致的報酬率計算錯誤
- 修正
finlab.portfolio中PortfolioSyncManager在update時,產生非必要性warning
1.2.5 (2024-7-29)
Feature
- 新增股票儀表板中,隱藏股票名稱的功能
Fix
- 修正股票儀表板中
open_close_avg為「平均價」 - 修正報酬率的計算方式,不同期之間不需要計算交易手續費
- 修正儀表板中
NaN的狀況
1.2.4 (2024-7-28)
Feature
- 新增
finlab.portfolio的PortfolioSyncManager使用to_file和from_file來讀取資料
Fix
- 修正
finlab.portfolio使用PortfolioSyncManager處理零股報錯問題 - 修正
finlab.portfolio使用PortfolioSyncManager零股顯示小數點第四位
1.2.2 (2024-7-27)
Fix
- 修正
finlab.cli假如尚未初始化 nb 指令會報錯的問題 - 修正
finlab.portfolio雲端下載策略,找不到策略 raise Error 提供更詳細的錯誤訊息 - 修正
finlab.portfolio針對 live_trading_performance 為 None 報錯的問題 - 修正
finlab.portfoliocreate_mutli_asset_report 路徑與回傳數值的問題 - 修正
finlab.portfoliosyn manager 在停損停利時的報錯問題 - 修正
finlab.backtest將 resample=None 的時候,報酬率計算方式為持有期間報酬率 - 修正
finlab.backtest在盤中模擬時,計算收盤結算引入NaN造成的問題 - 修正
finlab.report針對每期報酬率分開時,顯示出場原因的問題
1.2.0 (2024-7-27)
Features
- 新增
finlab.backtest的盤中儀表板和累計報酬儀表板 - 新增
finlab.backtest模擬時,不論trade_at_price為何,所有結算均於盤後進行結算 - 新增
finlab.backtest考慮開盤買賣,收盤價決定停損停利 - 新增
finlab.report將report.trades新增產業別 - 新增
finlab.portfolio模組,用於將策略用於實際投資組合 - 新增
finlab.portfolio文件教學,用於教學如何將策略用於實際投資組合 - 新增
finlab.cli模組,用於命令行操作與下單 - 新增
finlab.cli文件教學,用於教學如何使用命令行操作與下單 - 新增 doc 介紹利用 regex 來選取產業別
- 新增
finlab.online功能,讓Fugle API可以自動登入不需人工輸入密碼
Fix
- 修正
finlab.sinopac中的帳戶餘額計算於星期天凌晨提早結算的問題
1.1.6 (2024-7-11)
Fix
- 修正回測中,離線版針對資料快取讀取的問題
- 修正回測中,Windows datetime 轉換成 int32 不支援的問題
1.1.4 (2024-7-9)
Features
- 新增策略到期時間,用於提醒資料已經過期,需要重新執行
- 回側面版:同時顯示進場與當前價格
- 回測面版:將預設報酬率顯示從後往前
- 回測面版:持股價格顯示優化
Fix
- 修正 finlab.tools.factor_analysis 會因為因子日期沒有對齊而報錯的問題
- 修正 Pandas 2.2.0 版本下,銜接 Pandas 3.0.0 產生的 Warning
- 修正 ffn_core 中,Tabular 建構錯誤的問題
- 修正 ffn_core 中,針對 Pandas 3.0.0 版本的兼容性問題
- 修正回測頁面股票進場價格顯示錯誤的問題
- 回測頁面:修正股票歷史紀錄
- 回測頁面:考慮近期最大下跌
- 修正 plot 中每年平均報酬,考慮沒有回測的狀況
1.1.3 (2024-6-4)
Features
- 將finlab.tools.factor_analysis 進行修正,支援多因子
- LINE Notify 新增策略名稱發送
Fix
- 修正 show_alerting_stocks 無法使用的問題
1.1.2 (2024-5-23)
Feature
- 新增 finlab.tools.factor_analysis 模組,用於因子分析
Fix
- 修正價格 NaN 的應對處理
- 修正 finlab.ml.feature.ta 函式的多核處理邏輯,根據單核心報錯
- 修正參照下次再平衡的時機,以部位變化日期為準,改成當前的收盤價格日期為準,避免在下次再平衡時,參照到錯誤的價格
- 修正 finlab.ml.qlib.get_models 中的模型,在訓練時 label 會有 inf 或 NaN 的問題
Refactor
- 針對銀行餘額與交割訊息重構
1.1.1 (2024-4-25)
Refactor
- 在 machine_learning.md 中新增 "必要安裝" 和 "模型函式庫(非必須)" 兩個小節,清晰劃分安裝指令。
- market_info.py 中 MarketInfo 和 TWMarketInfo 類別的方法 market_close_at_timestamp 和 tzinfo 進行了修正和標準化,以改善方法的可讀性和一致性。
- 將部分方法的實現從動態到靜態,以提高效率和減少依賴。
- 新增 qlib.py 中 WrapperModel 的 fit 方法中對 segments 參數的處理,確保自定義數據段可以被正確處理。
Fix
- 修正 market_info.py 中邏輯條件判斷錯誤,正確區分條件判斷式。
- 修改 data.py 中對於 NaN 值的處理方式,避免在計算指標時包含無效數據。
- feature.py 中 ta 函式的多核處理邏輯調整,根據核心數量決定數據處理方式,避免在 docker 中無法使用。
- 修正 label.py 中,使用 maximum_adverse_excursion 函式時的錯誤,確保函式正確運行。
- 修正 label.py 中,使用 maximum_favorable_excursion 函式時的錯誤,確保函式正確運行。
1.1.0
Features
- 新增了對 Microsoft Qlib 的支持,透過在 Dockerfile 中添加 pyqlib 依賴,使得用戶能夠直接在 Docker 容器中使用 Qlib。
Fix
- 修正了版本號在多個檔案中的不一致問題,統一將版本號更改為 1.0.10。
- 重構了 finlab/ml/qlib.py 中的代碼,移除了過時的註釋和未使用的代碼,提高了代碼的清晰度和維護性。
- 更新了 finlab/online 子模組的引用,以獲取最新的功能和修復。
- 簡化了 run_online_test.sh 和 run_all_test.sh 腳本,移除了不必要的註釋和代碼,使得測試過程更為簡潔高效。
1.0.6
- fix(report): 修正 importlib.resources 在 python<=3.6, python==3.8,3.7, python >=3.9 不能用的問題
1.0.5
- fix(report): 修正 importlib.resources 在 python<=3.8 不能用的問題
1.0.4
- feat(backtest): 新增回測與標的的相關測試功能
- fix(backtest): 修正 removing next_weight force to 1 的問題
- fix(us_market): 修正支援 market_close_at_timestamp support None 的問題
- chore(pandas 3.0): 支援新版的 Pandas >= 3.0.0 new resample string format
- feat(backtest): 新增 sl_enter 和 tp_enter,來代表立即停損停利,直到下次換股再買入的標示
1.0.3
Fix
- 修復支援網頁端執行回測
- 修正
report.current_trades假如有重複的股票名稱,以最新的部位為主 - 修正儀表板顯示每月營收的計算方式,從 1 號到 31 號,變成跟之前一樣,從上月 31 號到此月 31 號
- 修正
trail_stop在買同一張股票時,提早出場的問題 - 隔天要進場,同時又停損停利,針對
stop_trading_next_period對於report.action以及report.next_weights的顯示資料進行修正,並增加單元測試。
1.0.2
Refactor
- 移除 tailwind default css,改而使用 vite 輸出的 style.css
- 移除 web server 改而使用 iframe docsrc (經過測試支援所有平台)
Fix
- 顯示在 docker 上 web server port 無法使用的問題
1.0.1
Features
- 顯示移動停損
- 儀表板右上角控制 light/dark 模式
- 另存儀表板至指定的路徑下
Fix
- 修正 Windows 下 report 預設讀寫編碼為 cp950 造成的問題。
- 修正停損無法顯示
- Colab 中 CSS 字體與排版調整
- light/dark 模式中,圖表座標軸顏色響應
- 修正圖表記憶體沒有釋放,導致 tab 切換延遲的問題
1.0.0
Features
- 新增 Position.from_report 的單元測試
- 在多種條件下測試 report.next_weights 功能
- 推出全新儀表板介面
- 支援 Python 3.12 版本
Fix
- 修正了在啟用停損或停利時,報告中 report.next_weights 的正規化問題
- 解決了在 Pandas 的 reindex 函數中,分類型欄位無法正確索引的問題
- 修正了在添加運算子時,分類型欄位繪圖錯誤的問題
0.5.13
Features
- 整合 Pytest(提交 e7a487c):加入了 Pytest,讓測試更高效。
- finlab.ml 日內交易報酬率計算(提交 8804fb1):新增了計算日內交易的 label
- finlab.ml.feature.ta 特徵計算支持多進程(提交 1ab0463):在特徵計算模組中引入多進程支持,提升性能。
Fix
- 優化 'get_location' 函數(提交 253e98c):改進了 'data.py' 中的 'get_location' 函數,使其更好地處理失敗情況。
- 市場信息支持時區(提交 aa2756b & 79b3671):在 'market_info.py' 中加入了時區信息的處理。
- 移動停損修正(提交 6522bf7 & e7fc1f3):調整了 'backtest.py' 中的交易計算,修正移動停損的功能。
- Dataframe 的導入修正(提交 626ada1):修正了 'dataframe.py' 中的導入問題。
- 特徵初始化修正(提交 772d659):解決了 'ml/feature.py' 中的初始化問題。
- 強制雲端下載(提交 7ec28a3):修復了 'data.py' 中的 'force_cloud_download' 實現。
Other updates
- 重構(提交 26d1518):對 'online' 模組進行了重構,使代碼結構更好。
- 文檔更新(提交 44a93d4, 9f5683f, cd4a894):更新了 'backtest.py'、'data.py' 和 'ml/feature.py' 的文檔。
- 版本更新(提交 d361d7f):將版本升級到了 0.5.13。
- 增加測試覆蓋率(提交 350dfbc):在 Docker 配置中增加了測試覆蓋率。
- 測試系統的穩健性(提交 1647479):提升了測試系統的穩健性。
- 在線測試
Position.to_list(提交 f3d086f):更新了 'online_test.py',增加了轉換為列表的功能。
0.5.12
- 修正了 run_online_test.sh 中的在線測試更新價格,以包含 FUGLE 配置的環境變量。
- 調整了 online_test.py 中的 test_update_price,以正確比較浮點數量。
- 修改了 event_study.py,通過重新索引工作日使其與非交易日兼容。
0.5.11
- 修復 position 為零時,會報 error 的問題
0.5.10
- 永豐 API 下單大於 1000 元無法下單的問題
- 修正
FinlabDataframe的 memory leak error - 修正登入顯示的樣式,避免 colab 登入時出現 error
- 修正
data.search的問題
0.5.9
- 修正 dataframe operator 運算時的 reshape 問題
- 改善
df[bool_selector]無法使用的問題
0.5.8
- 改善
data.get速度 - 更新永豐 API 下單效率(然而引出一些問題,已經修復)
0.5.7 (2023-11-4)
Fix 🚀
FinlabDataFrame:若未設置則正確使用 UUID 修正了__hash__方法。hold_until方法:修正了self、exit和rank的reindex問題。market_info.get_market_info:更正了reindex邏輯,確保使用更新後的索引。fetch_data:修正了報告部分的日均計算錯誤。data.py:為 HTTP 請求添加了User-Agent標頭以防止取得錯誤。data.py:修正了保存空DataFrame的問題。ffn_core.py:修正了calc_sharpe方法中除以零的錯誤。
Features 🚀
tools: 新增finlab.tools.event_study研究事件交易等相關功能。backtest.py:引入了fast_mode,在不考慮停損或停利的情況下進行快速回測。dataframe.py:將index_str_to_date方法進行了緩存,提高性能。report.add_trade_info:導入 Cython 優化運算速度。setup.py:編譯 Cython 擴展時啟用 O3 優化。backtest.py:為sim函數新增文檔,詳細說明新特性和參數。dataframe.py:實現了索引優化,將字符串索引轉換為日期並進行緩存。- 調整
setup.py,將 Python 版本要求從 >=3.7 改為 >=3.6。 - 更新子模組至最新提交。
Tests 🚀
- 為
report_test.py模塊新增測試,以保證查詢功能的正確性。 - 為
report_test.py新增多個針對不同數據類型的測試案例。 - 更新
run_test_docker.sh腳本,包含新的測試案例。
0.5.2 (2023-09-28)
Fix 🚀
- 在少部分的 OS 上出現 recursive import 的問題
- 修正 liquility analysis 中產生 NaN 時,被 Pandas 暗自轉換成 float 造成的問題
- trade_at_price 修正
- 修正在嘗試 merge 過程中消耗大量記憶體的問題
0.5.0 (2023-09-14)
Features 🚀
- 新增移動停損功能
sim(..., trail_stop=0.1)來設定移動停損。 data.universe支援market='etf'另外,也可以選 ETF 的種類如:domestic_etf,foreign_etf,leveraged_etf,vanilla_futures_etf,leveraged_futures_etfdata.get支援從美國、台灣兩地更新資料,會自動選擇比較近的伺服器來索取資料。data.get自動偵測並連結 Google Drive 來存放下載的資料。data.get將全面支援在本地端更新資料,以後再也不用全面下載所有資料,而是下載 patch 並藉由本地端的程式來進行維護,只有在必要的時候進行整批資料的重置(預設開啟)sim(..., trade_at_price)可選擇其他價格來模擬買賣,可選'close'、'open'、'open_close_avg'、'high_low_avg'或 'price_avg'。- 新增底層功能以確保新的網站能夠兼容
Fixes
- 修正做空的停損停利
- FinlabDataFrame.hold_until 現在輸出為 bool (而非以前的 int)
- FinlabDataFrame 更廣泛的支援自動 reshape 與填值的運算,例如「&=」、「+=」等目前已支援
- 移除了強制設置的 logger
- finlab.online 修正了獲取總餘額時的時區問題。
- data.FileStorage 解決了 Windows 系統上的文件路徑錯誤。
- ffn 移除即將不支援的語法,更新了 pandas2.1 間容的語法。
- 自動偵測 backtest(position) 中的 position.index 轉換為 datetime
- 解決 report.trades 太長上傳的問題
- 解決回測時上次出場的標的,這次不進場的錯誤
0.4.6 (2023-08-11)
Fixes 🔧
- 修正優勢價格買賣(extra_bid_pct)在委託價格超過漲跌停價時的委託失敗問題,委託價以漲跌停為上限。
- 解決了下單 API 中 Position.from_report 停損停利部位判斷錯誤的問題。
- 解決了永豐 API 零股改價失敗問題,自動刪單再重下。
- 月營收索引改為 datetime 格式,解決 data.set_storage 模式下強制下載月營收資料的問題。
- 避免 finlab.dataframe.industry rank() 出現 nan 數值。
Features 🚀
- 加入策略報籌率統計分析圖表功能 finlab.plot.StrategyReturnStats。
- Fugle 行情 API v1.0 版 相容 finlab.online,不相容 v0.3。 提醒用戶請將行情 API v0.3 版本升級至最新的 v1.0 版本,舊版本將被 Fugle 官方棄用,要注意在行情 API v1.0 版本中,採用了不同的身份驗證方式,因此 v0.3 的 API 金鑰將無法適用於 v1.0 的 HTTP API 和 WebSocket API。您需要重新申請 API 金鑰以使用最新版本的 API。請前往金鑰申請頁面進行申請。
- 新增下單 API 於「更新委託單價格」時支援優勢價格買賣(extra_bid_pct)的功能,以高於成交價的 x%買入,低於成交價的 x%賣出。
0.4.5 (2023-07-05)
Fixes 🔧
- 解決了在 hold_until 中 rank 參數 inf 導致的排名功能失效問題。
- 修正了 alphalens 在 pandas 2.0 版本上的不相容問題。
- 解決了永豐 API 下單時,零股市價無法下單的問題,現在改成漲跌停下單。
- 針對 candle plot 的標題顯示位移問題進行了修正。
- 修正了 report.position 丟入 sim 後得到一致結果的問題。
- 解決了 edge ratio 時間序列排序問題,現在可以按時間順序排序。
Features 🚀
- 加入 us_universe 選擇美股子產業的功能。
- 新增下單 API 支援優勢價格買賣的功能,現在可以以高於成交價的 x%買入,低於成交價的 x%賣出。
Doc 📚
- 新增美股策略範例,提供用戶參考和學習。
- 新增在 data.indicator 中使用美股時的 market 參數說明,使用者可以更容易理解其使用方式。
0.4.3 (2023-05-11)
Warnings: Backtesting result and performance will change.
Features 🚀
- Improved RAM usage by removing sorting and swaplevel for machine learning features (e081c924).
- Optimized backtest report (8babbd7a).
- Implemented cross-validation for machine learning (e55828c0).
- support infomation for stop loss and take profit assets (5f9272f3).
- Hold_until functionality made available for US data (8437d62).
- Added indicators control in plot_stats (7364d58).
Fixes 🔧
- Fixed deadline considering business date for DataFrame (312f2fe1).
- Fixed the issue where a float object had no attribute 'month' (d51a5901).
- Fixed run_all_test (6203f56f).
- Prevented deletion during map iteration in backtest_core (2d1d9b05).
- Fixed login info (d177ed47).
- Fixed alpha annualize estimation in analysis (26a8becf).
- Fixed issue with short selling in online module (919521b9).
- Synced win_ratio in maeMfeAnalysis (a9a31189).
- Added rotc deadline in DataFrame (ac10597).
Refactoring 💡
- Refactored f_disclosure_date to_business_date, removed date too far, and improved speed (7dcb203b).
- Refactored market selection according to DataFrame columns (039cbc96).
- Fixed bugs and future warnings in the analysis module (ec93088f).
- Refactored environment name capitalization in login module (635caed4).
- Refactored login to use FINLAB_API_TOKEN (a5c9064d).
- Informed free users that data is limited (bbabad14).
Tests 🧪
- Added test_hold_until (ccc4ba89).
Doc 🗂️
- Updated daily_sortino documentation (b7d1d91d).
- Updated get_data documentation (276862c2).
0.4.2 (2023-04-27)
新增功能:
- 在機器學習中加入了標籤交易價格的功能
- 在報告中新增了 report.display() 的使用說明
- 在市場資訊中新增了美國市場資訊
修復問題:
- 在線上程式中修正了顯示字串的問題
- 將回測功能回復到穩定版本
- 調整回測功能中根據進出場價格調整持倉的問題
- 修正 qlib.init 的偵測問題
- 在報告中修正了基準指數時區的問題
- 處理了 pandas 2.0.0 版本兼容性問題
- 處理了 talib 依賴性問題
- 修正了在回測功能中進出場比例為 nan 的問題
- 在文檔中修正了 fugle Account numpy 的引用問題
其他:
- 在機器學習中新增了相關文件
- 在市場資訊中新增了相關文件
0.4.1 (2023-04-14)
- (fix): fugle np not found
0.3.19 (2023-04-04)
- (improve): memory usage in machine learning feature creation
- (improve): machine learning feature for different freqnecy index
- (fix): data.indicator support almost all talib functions
- (fix): 2023/4/10 monthly revenue reveal change to 2023/4/12
- (fix): sinopac calculate account balance
0.3.18 (2023-03-28)
- (Breaking): update shioaji >= 1.0.0. Please refer to finlab.inline module
- (feat): finlab.ml (document are not ready yet)
- (feat): support qlib data
- (feat): report add yearly and monthly return table
- (fix): backtest entry exit signal both activate conflict
0.3.12 (2022-11-29)
- (Breaking): report.get_stats() has new format
- (feat): data.get now read expire date from server and update data dynamically
- (feat): add a bunch of analysis for backtesting report
- (feat): getpass password to hide api_token
- (fix): report.weight and report.next_weights remove considering of price changed
- (fix): backtest(..., resample_offset='10d') fix backtesting display date
- (fix): finlab.online.order_executor show_alerting_stocks fix price
- (fix): fugle order status not change even when it is filled
- (fix): support update price of fraction lot size
0.3.11 (2022-11-10)
- (Fix) finlab backtest asset shorting fee miner adjust
- (Fix) finlab.report.weights and finlab.report.next_weights not defined
- (Fix) fugle-trade remove flag accoding to 0.4.0
- (Fix) fugle-trade fetch other source when stock.close is nan
- (Fix) fugle-trade FugleAccount.get_position not latest position
- (Feat) finlab.data.universe('STOCK_FUTURE') subset of TWII stocks
- (Feat) add yearly return when upload report
- (Feat) add fugle_trade version not compatable warning
0.3.10 (2022-10-13)
0.3.9 (2022-10-13)
- (Fix) finlab.online.sinopac_account order_lot position zero
- (Fix) finlab.online.fugle_account order_lot position duplicated
- (Fix) finlab.backtest weight display remove normalized
- (Fix) finlab.data windows FileStorage fix
- (Fix) finlab.data indicator exception error
0.3.8 (2022-9-27)
- (Fix) finlab.online.order_executor price +-10% limit order restricted
- (Fix) finlab.online.order_executor Position.from_report handle price=0, weight=0, and duplicated stock id
- (Fix) finlab.plot.StrategySunburst compatibility
- (Fix) finlab.report.display display multiple chart
0.3.8.dev1 (2022-9-27)
- (Fix) talib abstract module incompatible
- (Fix) backtest result: alpha and beta
- (Fix) finlab.online.panel
- (Fix) finlab.online.fugle_account stock not traded error
- (Fix) add cert custom password for sinopac
- (Fix) remove duplicated columns from unnumeric_dtype.
- (Fix) KY company disclosure deadline
- (Chore) Candlestick data format generalized
- (Chore) raise error when data.get not found
- (Chore) logger.info to logger.warning in finlab.data
- (Chore) fig return for report.display
- (Feat) add retain_cost_when_rebalance flag
0.3.7.dev1 (2022-8-8)
- 針對 touched_exit 做更細部的回測:
- 原本觸價反彈後不會被列入觸價賣出,現在會模擬觸價賣出
- 原本開盤跳空,會沒辦法賣在 0.07,現在也會賣在更低的位置
0.3.5.dev (2022-7-18)
- 新增 finlab.optimize 枚舉條件組合回測
- 新增 mae_mfe 圖表
- mae_mfe 做空分析
- report.get_trades()['position'] 改成 weighting
- backtest touched_exit 修正
- 修復 finlab.analysis bugs
0.3.3.dev (2022-7-1)
Bugs 修正
- 修正放空股票的 weight 權重顯示問題
- TreeMap 繪圖修正
- 財報公佈歷史時間修正
Analysis 分析回測結果
新增 Analysis 架構,可以將回測結果完整分析。 之後的分析都將繼承 Analysis 並且顯示圖表,讓 report 使用起來更豐富!
liquidityAnalysis 流動性測試
策略會模擬股票在收盤或開盤價買進賣出,但實際上,股票也有可能沒辦法順利交易,例如遇到處置股、全額交割股,或是長跌停板。 liquidityAnalysis 會檢測回測時,是否有買到這類行的標的,並且計算比例,已確保策略的流動性符合您的資金需求。 查看更詳細的教學文章。
inequalityAnalysis 不等式測試
原本已經有策略,想要額外加入其他技術指標、籌碼、獲利指標,可以透過 inequalityAnalaysis 來檢視是否能夠提高選股績效。 以股價淨值比而言,我們想觀察以股價淨值比來進一步篩選股票的績效,可以用以下的方式:
要如何看結果,可以參考更詳細的教學文章。
0.3.2.dev (2022-6-23)
SunBurst 檢視策略部位
可以顯示當前的股票,有哪些產業,產業的偏重是哪一塊,查看詳細內容!
做空以及個股權重
FinLab Package 終於支援做空了,假如你原本就有一個好策略,可以做空 0050 試試看,雖然報酬率可以能會下降,但是風險也會大幅縮小!非常適合我們做多檔股票資產配置使用。
另外值得一提的是,新的版本 position 除了以前的布林訊號 (True/False) 外,也可以使用權重!所以下方程式碼,就是 50% 比重給 2330 做多,50% 給 1101 做空。
這樣的權重分配方式,完全兼容之前的版本,也就是 position 是 True / False 的狀況,因為 True 在電腦運算中,本來就代表 1 ,而 False 代表 0。權重都是 1 的情況下,程式就會跟以前一樣平均分配資產喔。
from finlab import data
from finlab import backtest
close = data.get('price:收盤價')
position = close < 0
position['2330'] = 0.5
position['1101'] = -0.5
r = backtest.sim(position)
r.display()
支援 Pandas_ta 計算技術指標
Pandas_ta 最近一兩年算是計算技術指標的後起之秀,原因在於 TaLib 有時候實太難安裝了,而且技術指標就只有那 100 個,都是老調重彈,沒有更新。有鑒於此,Pandas_ta 採用純 Pandas 計算技術指標,跟不同的作業系統有比較好的相容性。另外,Pandas_ta 也有很多最新的技術指標,例如 supertrend indicator。有非常多沒有看過的指標,像是「Even Better Sinewave 」,聽起來實在是非常有趣呀!這些都可以在 Pandas_ta 文檔中找到。