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

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

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

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

解決済

execを関数に組み込みたい

754x
754x

総合スコア14

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

1回答

0リアクション

1クリップ

159閲覧

投稿2022/10/04 06:52

前提

csvファイルをデータフレームに読み込む際に、ファイル名ごとに列選択して読み込みたい

これを実現するためにexec関数を用いたところ、エラーは出力されませんがexec関数が通っていないという事象が起こりました。

実現したいこと

csvファイルをデータフレームに読み込む際に、ファイル名ごとに列選択して読み込みたい

該当のソースコード1(正しく動くコード)

Python

test_arr = [column1,column2] test= "テスト" df = pd.read_csv(FOLDER+test+".csv", sep=',') print("選択前:" + str(len(df.columns))) #出力 100 exec_command = "df = df["+test+"_arr]" exec(exec_command) print("選択後:" + str(len(df.columns))) #出力 2 #以下dfを操作し可視化を行いますが、本題と関係がないので省略します #出力 選択前:100 選択後:2

該当のソースコード2(正しく動かないコード)

Python

test_arr = [column1,column2] def select(test): df = pd.read_csv(FOLDER+test+".csv", sep=',') print("選択前:" + str(len(df.columns))) exec_command = "df = df["+test+"_arr]" exec(exec_command) print("選択後:" + str(len(df.columns))) #以下省略 test = "テスト" select(test) #出力 選択前:100 選択後:100

試したこと

関数として定義するとexecが動いていないことが確認できていますが
exec関数を使うのが初めてなこともあり、原因がわかりません

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

Windows11
VSCodeでipynbファイルで動かしています

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

melian

2022/10/04 08:11 編集

read_csv() には usecols というキーワードがあって、読み込むカラムを指定することができます。 df = pd.read_csv(FOLDER+test+".csv", sep=',', usecols=test_arr)
754x

2022/10/04 08:31

ありがとうございます。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。