インタラクティブ・ブローカーズ証券(以下IB証券)のTrader Workstation (トレーダー・ワークステーショ)(以下TWS)のAPIを利用します。口座開設など、いくつかこの段階でハードルがありますが、本記事ではすでに口座開設が行われている前提での生地となります。
日系の証券会社を含めて、TWSはもっとも高機能なツールだと思います。とくに、API連携など、その拡張性など考えても、個人投資家にとっては、現在利用できるツールのうちの最高峰のものであると思っています。
現実的・具体的な利用方法として、本記事では過去データの取得にフォーカスして記述していきま、その設定に必要な手順や、備忘録として書いておきます。
準備・チェックポイント
3つの設定が必要となります。
1.手元PC(Windows10)でPythonが使えるようにする設定
2.TWSのAPI経由でIB証券サーバーに接続するための設定
3.PythonでIB証券に問い合わせを行うコーディング
の3点が重要になってきます。
Python3.9.2のダウンロードとインストール
3.9.2を選んだ理由は現在私が利用しているバージョンだからです。爆
コードを移植したときに問題なく動くようにするために、必要な労力を最小にしたかったからです。爆爆
ダウンロードリンク:
data:image/s3,"s3://crabby-images/9f4af/9f4af4e45ddf93c286a67105ec22fec645cb215f" alt=""
data:image/s3,"s3://crabby-images/901ae/901ae364bf2d0dd4a0264406c9ae3b5cc6b2121c" alt=""
今回は一番下のWindows Installer (64-bit)を選択しました。
インストールファイルの実行:
data:image/s3,"s3://crabby-images/5c61c/5c61c95db42a31bd9be268031a70dcbd8f70f509" alt=""
PATHは入れるように指定します。Install Nowで開始します。
data:image/s3,"s3://crabby-images/baeba/baebaba6c4d44b0437f67bcb14f7c75dfbaddf14" alt=""
はい、で管理者権限で実行します。
data:image/s3,"s3://crabby-images/b2b9b/b2b9be8b66717c8f8f0d807187c9f9e71f785f9c" alt=""
data:image/s3,"s3://crabby-images/7d267/7d267d92ca299a31fd7fd17471ce4c87bf978cd5" alt=""
Disable path length limit などありますが、特に指定せずに Close をクリックしてインストール自体は終了。
Pythonのインストールされているか確認
実際にインストールされているかコマンドプロンプトを起動して確認します。
data:image/s3,"s3://crabby-images/66c66/66c66b278b86357f0b298f186d2d58fc68fddc70" alt=""
インストールされているか確認のコマンド
python --version
data:image/s3,"s3://crabby-images/aa2ad/aa2ad354d3da2495c74abb8884a562da8b2b2da1" alt=""
3.9.2がインストールされている様です。
Jupyter Notebookのインストール
事前にpipのアップグレードをしておきます。
コマンドプロンプトを管理者として実行して以下のように実行します。
data:image/s3,"s3://crabby-images/8a058/8a058891e4d26aae93b6d6fc4036fa1d3ac8f9b8" alt=""
data:image/s3,"s3://crabby-images/e7ab8/e7ab86511078bed381c205085df736af6a8d4747" alt=""
python -m pip install --upgrade pip
Jupyter notebookのインストール
pip install notebook
data:image/s3,"s3://crabby-images/3eeff/3eeffb83c06d4aefceea93d861b7168c414965f2" alt=""
data:image/s3,"s3://crabby-images/5cd2c/5cd2c11930e278b1f823d86116b42c4cbb2822f4" alt=""
Jupyter Notebookの起動チェック
Jupyter Notebookはコマンドプロンプトから実行するのですが、実行したディレクト以下のファイルが参照されるので、まず先にディレクトリ構造を決めておきます。
今回の例ではGoogleドライブの直下にPythonというフォルダを作って、その中に起動コマンドや関連のpython関係のファイルを置いていくディレクトリ構造にします。
data:image/s3,"s3://crabby-images/aa0ee/aa0ee60c58a784c413e5bb60d28d9e04f20f37cb" alt=""
コマンドプロンプトのショートカットを
G:\マイドライブ\python
フォルダの下にコピーしておきます。
このショートカットのプロパティを選び、作業フォルダーの情報を空欄にします。
data:image/s3,"s3://crabby-images/9da4b/9da4bc5b3f79ac3f449788e963cf6622cfbb709a" alt=""
data:image/s3,"s3://crabby-images/21301/21301f51880e463d2b4c2bccd5c18f6fccd2b88e" alt=""
このようにすることで、次回このショートカットを実行すると現在のディレクトリで実行することができます。
data:image/s3,"s3://crabby-images/e06b6/e06b6222a869dd0907ae550ff2b7dd2b7fde34e5" alt=""
Jupyter Notebookの起動
このコマンドプロンプトで
jupyter-notebook
と打って起動するとChromeの新規タブでJupyterが起動します。
data:image/s3,"s3://crabby-images/fcae1/fcae106d609c982b34eaa1d8abeac3de87c51604" alt=""
data:image/s3,"s3://crabby-images/fca6e/fca6e4d6adac684b3454c232ccc2091745de241b" alt=""
IB証券のTrader WorkstationでAPI接続を可能にする設定
データの取得はインタラクティブ・ブローカーズ証券(以下IB証券)のTrader Workstation (トレーダー・ワークステーショ)(以下TWS)のAPIを利用します。口座開設など、いくつかこの段階でハードルがありますが、本記事ではすでに口座開設が行われている前提で進めます。
IB証券からのAPI接続に関する情報は以下のようになります。
data:image/s3,"s3://crabby-images/05867/058672cc60c7dadb299e52a5dc6ac28c8137e2ab" alt=""
日系の証券会社を含めて、TWSはもっとも高機能なツールだと思っていますが、API連携など、その拡張性など考えても、個人投資家にとっては、現在利用できるツールのうちの最高峰のものであると思っています。
現実的・具体的な利用方法として、本記事では過去データの取得にフォーカスして記述していきます。
基本的にはTWSのダウンロード・インストール、API接続を可能にするように設定を行うことで可能です。
ソフトウェアーのダウンロードは以下のサイト
data:image/s3,"s3://crabby-images/94486/94486cc937844a6df5142f04b48296ff6496d23b" alt=""
data:image/s3,"s3://crabby-images/813a8/813a88963c43570f1454c35bda708665cf740380" alt=""
data:image/s3,"s3://crabby-images/20fb5/20fb577492b8b89bef4556f057ad4d0de841c377" alt=""
OSによってダウンロードするキットは変わりますが、上の例ではWindowsの安定版のダウンロードをするようになっています。
インストールは以下のような画面が出てきて、進めていきます。
data:image/s3,"s3://crabby-images/51ec0/51ec00ea4d33e6ed7a9f74713207c52ab22ada4b" alt=""
data:image/s3,"s3://crabby-images/c7437/c74375299607990e3316fe097a8c0686b7a04e5f" alt=""
I accept the terms in the license Agreement にチェックを入れて進めていきます。
data:image/s3,"s3://crabby-images/d3370/d3370d383fd4ac3322b332488cb8d8afcf89acf5" alt=""
インストールディレクトリは変更せず進めていきます。
data:image/s3,"s3://crabby-images/aef49/aef491557f7fb2975b5966a98ebf0960482de3f5" alt=""
終了です。
Windowsで問題なくインストールできていればディフォルトでは
C:\TWS API\source\pythonclient
のディレクトリに以下のようなファイル群がインストールされていると思います。
data:image/s3,"s3://crabby-images/edf20/edf2020918d203e37b96e0808e976a93bfd3eb01" alt=""
実際の設定はTWS側で行います。
TWSにログインしたののち、 Edit>Global Configurationもしくは歯車のボタンから設定していきます。
data:image/s3,"s3://crabby-images/1026b/1026ba65db92d89a5d8cd9041fbe6cc54acbac72" alt=""
もしくは
data:image/s3,"s3://crabby-images/a1e97/a1e97f342fc71cd3fef26873de8cfc1a1c288a70" alt=""
TWSのAPI接続設定の入力値
Trader Workstation Configurationウィンドウ内で、以下のような設定にすることで可能です。
data:image/s3,"s3://crabby-images/1ced2/1ced2f8691da28f297eb2b2edbea8dd43fc6612b" alt=""
Enable ActiveX and Socket Clients : API接続するには必要です。
Read-Only API : API経由で新規注文を送る場合は外す必要がありますが、読み込みのみという場合はONでも問題ありません。ただ、Pythonでコードを実行した場合にここのチェックがついてますよと、リマインドされます。
Socket port : 7497 を使っていますが、リアルタイムデータを使いたい場合などは7496を使うようにといわれています。ここの数字はPtyhonのコードと数字をあわせることで接続可能となります。
Allow connections from localhost only : 安全のためにつけておくのが良いと思います。
TWSサイドの設定は以上になります。
PythonでIB証券に問い合わせを行うコーディング
2023/02/16追記:いつくかのバージョンの不整合により正常に動かない場合があるようです。
以下のバージョンでは正常に動くことを確認していますので、そのバージョンを利用することを強くお勧めします。
ib_insync==0.9.70
pandas==1.3.1
追記終了
まずは必要なライブラリとして ib_insync というというものをインストールします。
pip install ib_insync==0.9.70
data:image/s3,"s3://crabby-images/c11c6/c11c6d045ed6573bc327f95160f103d1289027cd" alt=""
あと、必要に応じてpandasなど必要な他のモジュールもインストールしておくといいと思います。
pip install pandas==1.3.1
もしくは
pip install pandas==1.3.1 --user
data:image/s3,"s3://crabby-images/e9c8e/e9c8e61c25669fa6d6d35a2864d5f96792f80163" alt=""
Jupyter Notebookでの動作確認
インストールできた場合はJupyter Notebookから動作確認をしていきます。
data:image/s3,"s3://crabby-images/4a125/4a125b2bde560d871647b0dba8672a1fed00f7cb" alt=""
新規のPython3のファイルを作ります。
以下のコードを実行します。
from ib_insync import *
import random
import pandas as pd
util.startLoop()
ib = IB()
ib.connect('127.0.0.1', 7497, clientId=random.randint(0, 29))
contract = Forex('EURUSD')
bars = ib.reqHistoricalData(contract, endDateTime='', durationStr='30 D',
barSizeSetting='1 hour', whatToShow='MIDPOINT', useRTH=True)
df = util.df(bars)
display(df[['date', 'open', 'high', 'low', 'close']].head())
data:image/s3,"s3://crabby-images/82212/82212d2be14bd75ca6e724fd889fe3e40b4d64e9" alt=""
data:image/s3,"s3://crabby-images/f2399/f2399d06847242af771e7578e97b866428c32247" alt=""
今回の例ではAPI接続ではリードオンリー(読み込みのみ)としていましたのでこのようなメッセージが出ますが、データ取得については問題ないので、「クローズ」を押します。
問題なければ以下のようなデータが取得できるはずです。
data:image/s3,"s3://crabby-images/b217b/b217b60ed9964752aae6d760893eed418427c999" alt=""
お役に立てましたでしょうか。
投資に関する免責事項
情報の提供・作業代行を目的としており、投資勧誘を目的とするものではありません。
—
IB証券関係、投資関係、Python関係の記事になります。
コメント