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

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

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

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

Python

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

Q&A

解決済

1回答

249閲覧

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

Sariha

総合スコア3

Python 3.x

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

Python

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

0グッド

0クリップ

投稿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

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

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

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

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

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

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

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

回答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

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問