質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

493閲覧

pythonでwebデータをExcelへ転記

dra_naka

総合スコア4

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2023/12/23 13:10

編集2023/12/30 04:14

実現したいこと

pythonからYahooFinance指定データを取得し、指定Excelへ転記するコードを作成したく、教えていただけないでしょうか?

完成状態は、pythonコードのtickers変数にある終値データを図1のG7(1つ目)、
G8(2つ目)....へ転記。
またtickers変数の0番目データには日付が入っており、こちらはA1セルへ転記。

図1
イメージ説明

前提

・APIをyfinanceを使用しております。

発生している問題・エラーメッセージ

①図1のファイルに図2が上書きされてしまう。既存ファイル(図1)に対して転記されるようにしたいです。
②tickers変数の最後データのみ転記されてしまう。

図2
イメージ説明

該当のソースコード

python

1import datetime 2import yfinance as yf#yahooファイナンスAPI 3import openpyxl 4 5# 転記先のExcelファイルパス 6excel_path = 'C:\\Users\\nakagami\\亮太\\21_資産運用\\資産運用\\テスト_保有株ポートフォリオ.xlsx' 7wb = openpyxl.load_workbook(excel_path) 8ws=wb['保有'] 9c1=ws['B1'] 10 11#ステップ1:yahooファイナンス情報を取得 12#ターゲットを指定 13tickers = ["1655.T", "2002.T"] 14 15#ステップ2:取得情報をExcelて転記 16for i, ticker in enumerate(tickers): 17 data = yf.download(ticker, period='1d', interval="1d") 18 19 # 更新日を転記 20 if i == 0: 21 today1= datetime.date.today() 22 today2= "{0:%Y/%m/%d}".format(today1) 23 c1.value = today2 24 25 # 終値データを指定セルに転記(G7から) 26 closing_prices = data['Close'] 27 for j, value in enumerate(closing_prices): 28 ws.cell(row=7 + i, column=7 + j, value=value) 29 30wb.save(excel_path)

補足情報(FW/ツールのバージョンなど)

仕様環境は、python 3.12になります。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

dra_naka

2023/12/24 01:15

言葉足らずで申し訳ありませんでした。 調査したこと、試したことは、該当コードにもりこんだ結果になります。
guest

回答2

0

Excelファイルに追記・上書きしたいのであれば openpyxl などの他のモジュールを使うのが良いでしょう。

参考:
Excelファイルを読み込むPythonライブラリを比較してみた

投稿2023/12/23 13:26

meg_

総合スコア10890

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

dra_naka

2023/12/24 01:07

連絡ありがとうございます。 openpyxlバージョンも作成したのですが、完成状態のように転記することができませんでした。 import pandas as pd import matplotlib.pyplot as plt import numpy as np import datetime import yfinance as yf from openpyxl import load_workbook # ターゲットを指定 tickers = ["1655.T", "2002.T"] # 出力先のExcelファイルパス excel_path = r'C:\Users\nakagami\亮太\21_資産運用\資産運用\テスト_保有株ポートフォリオ.xlsx' # 出力先のシート sheet_name = '保有' # データを収集して終値を転記 for i, ticker in enumerate(tickers): data = yf.download(ticker, period='1d', interval="1d") # 日時データをA1セルに転記 if i == 0: data.to_excel(excel_path, sheet_name=sheet_name, startrow=1, startcol=1, index=False) # 終値データをG7, G8, G9などに転記 closing_prices = data['Close'] ws = load_workbook(excel_path)[sheet_name] for j, value in enumerate(closing_prices): ws.cell(row=6 + i, column=6 + j, value=value) # 保存 load_workbook(excel_path).save(excel_path)
meg_

2023/12/24 03:29

この欄ですとコードのインデントが消えてしまうので質問に上記コードを追記いただけないでしょうか?
meg_

2023/12/24 03:32

> load_workbook(excel_path).save(excel_path) インデントが分からないのでループ処理の範囲が不明ですが、おそらく上記コードは下記コードの間違いではないでしょうか? ws.save(excel_path)
dra_naka

2023/12/24 11:59

連絡ありがとうございます。 該当ソースコードへコメントコードを更新させていただきましたのでご確認よろしくお願いします。 ws.save(excel_path)に変更しますと、エラーが発生してしまいました。
guest

0

自己解決

ご協力ありがとうございました。
解決することができました。
解決したコードは該当コードにて更新させていただきました。

投稿2023/12/30 04:15

dra_naka

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問