お世話になります。
https://qiita.com/blog_UKI/items/f782fb86747e0bae89a9
上記ページを参考に勉強をしているのですが…
yfinance ライブラリを使用。
当期純利益データフレームの作成
次に財務諸表データをデータフレームにまとめます。まずはPERとROEを算出するための当期純利益です。各銘柄の決算期が揃っていないためNAN値が多いように見えますが、必要な箇所にはちゃんとデータが入っていますのでご安心ください。
> earnings = [] # 当期純利益 > > dummy = tickers.tickers[0].financials.T["Net Income"] > dummy[:] = np.nan > > for i in range(len(tickers.tickers)): > try: > earnings.append(tickers.tickers[i].financials.T["Net Income"]) > except: > earnings.append(dummy) # エラー発生時はダミーを入れる > > earnings = pd.DataFrame(earnings).T # DataFrame化 > earnings.columns = stocks # カラム名の設定 > > print(earnings)
以降が上手く動作できません。
エラー内容追記
KeyError Traceback (most recent call last) ~\anaconda3\lib\site-packages\pandas\core\indexes\base.py in get_loc(self, key, method, tolerance) 3080 try: -> 3081 return self._engine.get_loc(casted_key) 3082 except KeyError as err: pandas\_libs\index.pyx in pandas._libs.index.IndexEngine.get_loc() pandas\_libs\index.pyx in pandas._libs.index.IndexEngine.get_loc() pandas\_libs\hashtable_class_helper.pxi in pandas._libs.hashtable.PyObjectHashTable.get_item() pandas\_libs\hashtable_class_helper.pxi in pandas._libs.hashtable.PyObjectHashTable.get_item() KeyError: 'Net Income' The above exception was the direct cause of the following exception: KeyError Traceback (most recent call last) <ipython-input-76-21ebd2ac4cd6> in <module> 9 try: ---> 10 earnings.append(tickers.tickers[i].financials.T["Net Income"]) 11 except: ~\anaconda3\lib\site-packages\pandas\core\frame.py in __getitem__(self, key) 3023 return self._getitem_multilevel(key) -> 3024 indexer = self.columns.get_loc(key) 3025 if is_integer(indexer): ~\anaconda3\lib\site-packages\pandas\core\indexes\base.py in get_loc(self, key, method, tolerance) 3082 except KeyError as err: -> 3083 raise KeyError(key) from err 3084 KeyError: 'Net Income' During handling of the above exception, another exception occurred: NameError Traceback (most recent call last) <ipython-input-76-21ebd2ac4cd6> in <module> 10 earnings.append(tickers.tickers[i].financials.T["Net Income"]) 11 except: ---> 12 earnings.append(dummy) # エラー発生時はダミーを入れる 13 14 NameError: name 'dummy' is not defined
①
dummy = tickers.tickers[0].financials.T["Net Income"]
dummy[:] = np.nan
上記はエラー対策をしているのかと推測しているのですが、具体的に何をしているのでしょうか?
ちなみにtickers.tickersは辞書型で、キーに0 がない為 KeyError: 0 が返ります。
分かる方、ご教示いただきたくお願いいたします。
追記
上記のエラーはmeg_様からのご教示により対応できましたが…
次の同様のコードにて動作不備が発生しました。
equity = [] # 自己資本 dummy=list(tickers.tickers.values())[0].balance_sheet.T["Total Stockholder Equity"] dummy[:] = np.nan for i in tickers.tickers: try: equity.append(tickers.tickers[i].balance_sheet.T["Total Stockholder Equity"]) except: equity.append(dummy) # エラー発生時はダミーを入れる equity = pd.DataFrame(equity).T # DataFrame化 equity.columns = stocks # カラム名の設定 print(equity)
上記の実行結果(結果1)は
1332.T 1333.T 1414.T 1605.T ^N225
2018-03-31 NaN 1.154590e+11 NaN 2.916679e+12 NaN
2018-06-30 NaN NaN 7.409500e+10 NaN NaN
2019-03-31 NaN 1.253530e+11 NaN 3.006479e+12 NaN
2019-06-30 NaN NaN 7.806600e+10 NaN NaN
2019-12-31 NaN NaN NaN 3.040774e+12 NaN
2020-03-31 NaN 1.326280e+11 NaN NaN NaN
2020-06-30 NaN NaN 8.359900e+10 NaN NaN
2020-12-31 NaN NaN NaN 2.736540e+12 NaN
2021-03-31 NaN 1.428330e+11 NaN NaN NaN
2021-06-30 NaN NaN 9.089500e+10 NaN NaN
となります。…が、1332.Tはエラーではないので1333.T,1414.T,1605.Tと同様にデータが取得できるはずなのです。
ちなみに上記実行後に上記コードの
dummy=list(tickers.tickers.values())[0].balance_sheet.T["Total Stockholder Equity"]
を
dummy=list(tickers.tickers.values())[1].balance_sheet.T["Total Stockholder Equity"]
とダミー作成用に使用するインデックスを変えると。
1332.T 1333.T 1414.T 1605.T ^N225
2018-03-31 NaN NaN NaN 2.916679e+12 NaN
2018-06-30 NaN NaN 7.409500e+10 NaN NaN
2019-03-31 NaN NaN NaN 3.006479e+12 NaN
2019-06-30 NaN NaN 7.806600e+10 NaN NaN
2019-12-31 NaN NaN NaN 3.040774e+12 NaN
2020-03-31 NaN NaN NaN NaN NaN
2020-06-30 NaN NaN 8.359900e+10 NaN NaN
2020-12-31 NaN NaN NaN 2.736540e+12 NaN
2021-03-31 NaN NaN NaN NaN NaN
2021-06-30 NaN NaN 9.089500e+10 NaN NaN
と1332.Tはエラーのままで追加で1333.Tまでエラー扱いになります。
(同様にインデックスを2,3と変えれば1414.Tもエラー扱い。1605.Tもエラー扱いになっていきます。)
ちなみに、tikersの中身を再度入れなおすと元の結果1に戻ります。
根本的にダミー作成のためにリストを作成して(適当な)該当tickersの.balance_sheet.T["Total Stockholder Equity"]を引っ張るだけで
for i in tickers.tickers:以降の.balance_sheet.T["Total Stockholder Equity"]に影響を与える意味が分かりません。。。。
理由と対策わかられる方、ご教示の程宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー