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

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

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

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

Python

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

Q&A

解決済

1回答

2030閲覧

Pythonでcsvを読み取り、辞書型に変換するためのfor文に入れない

tmp-user

総合スコア44

CSV

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

Python

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

0グッド

0クリップ

投稿2021/06/29 14:36

①Pythonでcsvファイル作成
②同一csvファイルを読み込み
③データを辞書型に変換してリストに追加

という処理を作りたいのですが、③が上手くいきません。

read()は動いているので、ファイルは作成できているはずなのですが、
そもそもfor文内にすら入りません。

なにか記述ミスがあるでしょうか。

ちなみにrowの行数を増やしてみても変わりませんでした。

Python

1import csv 2 3log = "./temp.csv" 4 5# 出力ファイル 6out_file = open(log,"w") 7 8# ヘッダ 9out_file.write("c1,c2,c3,c4\n") 10 11# データ 12row = "{},{},{},{}\n".format( 13 "data1", 14 "data2", 15 "data3", 16 "data4" 17) 18 19out_file.write(row) 20 21out_file.close() 22 23# 書き出したファイルのロード 24with open(log, 'r') as f: 25 26 print(f.read()) #これは出力される 27 28 testList = [] 29 30 # データ取り出し辞書型へ変換 31 for line in csv.DictReader(f): 32 print("ここが出力されない") 33 print(line) 34 testList.append(line) 35 36 print(testList) 37

出力

c1,c2,c3,c4 data1,data2,data3,data4 []

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

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

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

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

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

guest

回答1

0

ベストアンサー

# 書き出したファイルのロード with open(log, 'r') as f: print(f.read()) #これは出力される (★)

★のread()が実行された時点で、ファイルオブジェクトの読み込み位置が最後まで到達してしまっています。
こうなると、csv.DictReader(f)は何も読み込みません。

したがって**f.seek(0)**で、読み込み位置を先頭にもどしてやらないといけません。

... # 書き出したファイルのロード with open(log, 'r') as f: print(f.read()) #これは出力される この時点で読み込み位置が最後に到達。 f.seek(0) #読み込み位置を先頭に戻す。 testList = [] # データ取り出し辞書型へ変換 for line in csv.DictReader(f): ...

投稿2021/06/29 14:44

編集2021/06/29 14:49
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

tmp-user

2021/06/30 00:53

ありがとうございます! ファイル読み取りにはシークという考え方があるのですね。 全く知らないポイントでした。 わかりやすい回答をありがとうございます。 ベストアンサーとさせていただきました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問