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

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

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

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

Python

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

Q&A

解決済

csvファイル名の参照に関して

Sariha
Sariha

総合スコア3

Python 3.x

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

Python

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

1回答

0グッド

0クリップ

174閲覧

投稿2023/01/22 11:14

前提

初歩的な質問で恐縮ですが...
Pythonでcsvファイルの集計と可視化をしています.
describeメソッドを使って複数csvファイルに対して同時に統計値を算出しようとしているのですが,その結果をファイルに出力するタイミングでうまくいきません.

実現したいこと

-[1]フォルダ内の複数csvを読み込む
-[2]読み込んだcsvは結合せずそれぞれのcsvに対してdescribeメソッドを用いて統計値を算出する 
-[3]算出結果を別ファイルに保存する

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

上で説明した算出結果のファイル名に,できれば元々のcsvファイル名も含めたいのですがうまくいきません.

該当のソースコード

Python

1import datetime 2now = datetime.datetime.now().strftime('%Y%m%d%H%M%S') 3now 4 5#1---フォルダ内のCSVファイルの一覧を取得 6files = sorted(glob.glob('./*.csv')) 7#2---ファイル数を取得 8file_number = len(files) 9#3---CSVファイルの中身を読み出して、リスト形式にまとめる 10csv_list = [] 11for file in files: 12 csv_list.append(pd.read_csv(file,encoding='UTF-8')) 13 14i = 0 15for file in csv_list: 16 print(file.describe()) 17 file.to_csv('describe/'+now+'_'+str(i)+'_describe.csv', encoding='UTF-8') 18 i+=1

試したこと

安直に,上のfor文の中でstr(file)を使ってやろうとしたところエラーになりました.

Python(jupyter

1i = 0 2for file in csv_list: 3 print(file.describe()) 4 file.to_csv('describe/'+now+'_'+str(i)+str(file)+'_describe.csv', encoding='UTF-8') 5 i+=1 6 7OSError Traceback (most recent call last) 8/var/folders/xm/8c27lfvx4j7dstnx7sjhd1dr0000gp/T/ipykernel_1198/890094995.py in <module> 9 2 for file in csv_list: 10 3 print(file.describe()) 11----> 4 file.to_csv('describe/'+now+'_'+str(i)+str(file)+'_describe.csv', encoding='UTF-8') 12 5 i+=1

初歩的な質問で恐縮ですが,ご協力をよろしくお願いしますm(_ _)m

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

OS:macOS13.0 ventura
jupyter-lab 3.3.2
Python 3.7.13

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

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

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

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

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

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

melian

2023/01/22 11:26

for file in csv_list: この部分ですが、csv_list の中身はデータフレームなので、ファイル名にはなりません。元のファイル名が記録されているのは files という変数のはずなので、 for df, fname in zip(csv_list, files): とする方がよいのではないでしょうか。
Sariha

2023/01/22 11:44

確かにおっしゃる通りですね.気付きませんでした.ご指摘ありがとうございます. その方法で実施したところ,解決しました.ありがとうございました.

回答1

0

自己解決

以下のコードで解決しました.ありがとうございます!

Python

1for df, fname in zip(csv_list, files): 2 df_d = df.describe() 3 df_d.to_csv(str(fname)+'_describe.csv', encoding='UTF-8')

投稿2023/01/22 11:44

編集2023/01/23 05:50
Sariha

総合スコア3

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

  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

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

ただいまの回答率
86.02%

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

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

質問する

関連した質問

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

Python 3.x

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

Python

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