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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

Python

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

Q&A

解決済

2回答

1273閲覧

Pythonでcsvファイルの出力がうまくいかない原因を知りたい

ot1982

総合スコア6

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

Python

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

0グッド

0クリップ

投稿2020/09/30 09:15

pyhonでフォルダ名&ファイル名をcsvファイルに出力するプログラムを検討しています。
ファイル構成は下図のとおりです。
イメージ説明

プログラムを組んで実行したところ、エラーもなく、csvファイルも作成されていたので、
csvファイルを開いて確認したところ、何も値が書いてなくて、ファイル容量もゼロで出力されていました。
コードは以下のように作成しています。

import

1import pandas as pd 2import csv 3path = 'AAA' 4 5# ディレクトリ階層+中身 が各列に入る2次元リストを作る 6# [['AAA'], 7# ['AAA', 'test1.xlsx'], 8# ['AAA', 'BBB'], 9# ['AAA', 'BBB', 'test2.xlsx'], 10# ...] 11pathlist = [] 12for curDir, dirs, files in os.walk(path): 13 leaf = curDir.split('/') 14 pathlist.append(leaf) 15 for a_dir in dirs: 16 pathlist.append(leaf + [a_dir]) 17 for a_file in files: 18 pathlist.append(leaf + [a_file]) 19 20# 作った2次元リストをデータフレームにする 21path_df = pd.DataFrame(pathlist) 22 23# 重複削除 24path_df = path_df.drop_duplicates() 25print(path_df) 26 27# csvファイルに書き出す 28with open('sample.csv', 'w') as f: 29

print(path_df)で出力すると、下図のように出力されています。
イメージ説明

csvファイルに書き出すプログラムが、with open('sample.csv', 'w') as f: 以外にも必要なのでしょうか。
うまくいかない原因を知りたく、お分かりになる方ご教授よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

データフレームをCSVファイルとして書き出すなら、with open('sample.csv', 'w') as f:書かずに、そのままpath_df.to_csv('sample.csv')と書いて下さい。

ヘッダーやインデックスが不要なら、path_df.to_csv('sample.csv', header=False, index=False)のように指定します。

投稿2020/09/30 10:20

編集2020/09/30 10:21
Daregada

総合スコア11990

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

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

0

ファイルに書き出してるところがありませんよ
ファイルを作って、そこで閉じているだけ

Pandas のデータフレームを CSV ファイルやテキストファイルに出力する – Python でデータサイエンス

投稿2020/09/30 09:22

編集2020/09/30 09:24
y_waiwai

総合スコア87774

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問