🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python

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

Q&A

解決済

2回答

1294閲覧

csvファイルを読み込み、Pandasで処理する 複数のcsvファイルに対して1つのプログラムで実行したい

kumatakun

総合スコア7

Python

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

0グッド

0クリップ

投稿2021/03/10 20:49

python初心者になります。
pythonで株価分析を実施したいと考えております。
サイト(https://jp.investing.com/indices/japan-ni225)から銘柄別の株価の過去データを入手して分析をしたいと考えております。

現状は、20銘柄ほどのCSVファイルがあり、下記のファイル名を都度、入力して実行しております。

#CSVファイルの読み込み mydf1=pd.read_csv('book_6370.csv',index_col=0,parse_dates=[0]) mydf1=mydf1.sort_index()

銘柄が多数ある(CSVファイルが複数ある)ので都度ファイル名を指定して実行しておりますが、1つのプログラムの中で複数のファイルに対して同じ処理するコードが書けないか考えております。

globモジュールを用いて ディレクトリ内にCSVファイル名を抽出し、実行をできないかと思いましたが
下記のようなコードではエラーが発生します

import numpy as np import pandas as pd import glob #CSVファイルの読み込み for x in glob.glob('test_*.csv'): mydf1=pd.read_csv('x',index_col=0,parse_dates=[0]) mydf1=mydf1.sort_index() N=len(mydf1) print(mydf1.tail()) print(x)コード

エラーメッセージは下記のようなもので、globで読み込むのはできないのかと思いました

FileNotFoundError: [Errno 2] File x does not exist: 'x'コード

また、glogモジュールで読み込めたとしても、ファイルを読み込んだ後の処理(100行くらいのコードになってます)はfor 文以下で作成する必要があるのかな?と思っております。

複数のファイルに対して同じ処理を繰り返すことができるヒントなどがありましたらご教示いただけますと助かります。

よろしくお願いいたします。

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

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

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

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

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

jbpb0

2021/03/10 21:52

mydf1=pd.read_csv('x',... だと、「x」というファイル名のファイルを読むという意味になるので、glob.globの結果を使うなら mydf1=pd.read_csv(x,... とします
kumatakun

2021/03/10 22:57

ありがとうございます。基礎的なことをきちんと理解できず申し訳ありませんした。 大変助かりました。
guest

回答2

0

ベストアンサー

globについては、jbpb0さんとxail2222さんの書かれている通りです。
また、file名は、'book_.csv' なのか 'test_.csv' は確認しておきましょう。

くりかえしについては以下のように行います。

今の処理を、ファイル名を引数とする関数に書き換えます。
そして以下のように呼び出せばすべてが処理されます。

pytohn

1def my_func(filename): 2 mydf=pd.read_csv('x',index_col=0,parse_dates=[0]) 3 #やりたい処理 4 5for x in glob.glob('test_*.csv'): 6 my_func(x)

投稿2021/03/10 22:37

ppaul

総合スコア24670

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

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

kumatakun

2021/03/10 22:59

大変すっきりわかりました。def関数、if関数は勉強したつもりでしたが、このようにうまく使いこなせませんでした。if文の中でやりたい処理を強引に記載しようとしてましたがこちらのやり方が大変参考になります。 大変ありがとうございました。 またよろしくお願いいたします。
guest

0

mydf1=pd.read_csv('x',index_col=0,parse_dates=[0])

'で囲ってるので、中身がxの文字列になってますね...

投稿2021/03/10 21:53

xail2222

総合スコア1508

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

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

kumatakun

2021/03/10 23:00

ありがとうございます。基礎的なことで申し訳ありません。助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問