【本日のミッション】
Day62では「テキストファイルの読み書き」を学びました。
今日は、より実務でよく使われる CSVファイルの操作 を学びます。
CSV(Comma-Separated Values)は、表形式データを扱う一般的なフォーマットです。
Pythonでは標準ライブラリの csv モジュールを使うことで、簡単かつ安全に読み書きが可能です。
目次
CSVファイルとは?
CSVは「カンマ区切りのテキストファイル」で、Excelやデータベースでもよく利用されます。
例(sample.csv)
CSVファイルの読み込み(reader)
csv.reader() を使うと、CSVを1行ずつリストとして取得できます。
import csv
with open("sample.csv", "r", encoding="utf-8") as f:
reader = csv.reader(f)
for row in reader:
print(row)
出力結果
-
csv.reader()は各行をリストとして返す -
ファイルは
with open(..., encoding="utf-8")で安全に開く -
改行コードやカンマ処理も自動で行われる
CSVファイルの書き込み(writer)
csv.writer() を使うと、リストを1行ずつ書き込めます。
import csv
data = [
["名前", "年齢", "出身地"],
["田中", 25, "東京"],
["佐藤", 30, "大阪"]
]
with open("output.csv", "w", encoding="utf-8", newline="") as f:
writer = csv.writer(f)
writer.writerows(data)
print("CSV書き込み完了!")
出力結果
-
writerows()は複数行を一括出力 -
newline=""を指定しないと空行が入ることがある -
"w"モードは上書き、"a"モードは追記
辞書形式で扱う(DictReader / DictWriter)
CSVを「キー付きデータ」として扱いたい場合は DictReader や DictWriter が便利です。
読み込み例
出力結果
-
ヘッダー行(1行目)が自動的にキーとして使われる
-
辞書形式(dict)でアクセス可能
書き込み例
import csv
data = [
{"名前": "山田", "年齢": 22, "出身地": "札幌"},
{"名前": "高橋", "年齢": 27, "出身地": "名古屋"}
]
with open("people.csv", "w", encoding="utf-8", newline="") as f:
fieldnames = ["名前", "年齢", "出身地"]
writer = csv.DictWriter(f, fieldnames=fieldnames)
writer.writeheader()
writer.writerows(data)
print("辞書形式でCSV書き込み完了!")
-
writeheader()でヘッダー行を出力 -
各行は辞書として書き込む
CSVの追記(append)
既存のCSVにデータを追加するには "a" モードを使用します。
import csv
with open("people.csv", "a", encoding="utf-8", newline="") as f:
writer = csv.writer(f)
writer.writerow(["中村", 35, "広島"])
-
"a"は追記モード -
writerow()は1行のみ追加
練習問題
次のコードを実行したとき、正しい出力を選びなさい。
import csv
with open("test.csv", "w", encoding="utf-8", newline="") as f:
writer = csv.writer(f)
writer.writerow(["A", "B"])
writer.writerow(["C", "D"])
with open("test.csv", "r", encoding="utf-8") as f:
reader = csv.reader(f)
for row in reader:
print(row)
選択肢
A)
['A', 'B', 'C', 'D']
B)
['A', 'B'] ['C', 'D']
C)
エラーが発生する
D)
空の出力になる

解答
B)
['A', 'B'] ['C', 'D']
解説
-
writerow()は1行ずつ出力 -
csv.reader()は行単位でリストを返す
👉 正解は
B)
['A', 'B'] ['C', 'D']
✅ ポイント
-
CSVは
csvモジュールで簡単に読み書きできる -
reader()/writer():リスト形式 -
DictReader()/DictWriter():辞書形式 -
newline=""を指定して空行を防ぐ -
with open()構文を使って安全に扱うのが基本
次回予告
Day64では「JSONの読み書き(jsonモジュール)」を学びます。
Pythonでは標準ライブラリの jsonモジュール を使うことで、簡単にJSONの読み書きが可能です。
参考
Python 3 エンジニア認定基礎試験 – Odyssey CBT
Python3 エンジニア認定基礎試験 出題範囲と学習プラン
Python3 エンジニア認定基礎試験 練習問題 Day1:変数の基本
Python3 エンジニア認定基礎試験 練習問題 Day2:変数の型(int型とstr型)
Python3 エンジニア認定基礎試験 練習問題 Day3:算術演算子と代入演算子
Python3 エンジニア認定基礎試験 練習問題 Day4:文字列の操作
Python3 エンジニア認定基礎試験 練習問題 Day5:比較演算子と論理演算子
Python3 エンジニア認定基礎試験 練習問題 Day6:if文(条件分岐)
Python3 エンジニア認定基礎試験 練習問題 Day7:ループ処理(for文・while文)
Python3 エンジニア認定基礎試験 練習問題 Day8:break文とcontinue文
Python3 エンジニア認定基礎試験 練習問題 Day9:リスト(list)の基本
Python3 エンジニア認定基礎試験 練習問題 Day10:リストの操作(append,remove,len など)
Python3 エンジニア認定基礎試験 練習問題 Day11:リストのスライス(部分取り出し)
Python3 エンジニア認定基礎試験 練習問題 Day12:タプル(tuple)の基本
Python3 エンジニア認定基礎試験 練習問題 Day13:辞書(dict)の基本
Python3 エンジニア認定基礎試験 練習問題 Day14:集合(set)の基本
Python3 エンジニア認定基礎試験 練習問題 Day15:関数の定義と呼び出し
Python3 エンジニア認定基礎試験 練習問題 Day16:関数のデフォルト引数とキーワード引数
Python3 エンジニア認定基礎試験 練習問題 Day17:可変長引数(*args, **kwargs)
Python3 エンジニア認定基礎試験 練習問題 Day18:関数のスコープ(ローカル変数とグローバル変数)
Python3 エンジニア認定基礎試験 練習問題 Day19:ネスト関数(関数の中の関数)
Python3 エンジニア認定基礎試験 練習問題 Day20:ラムダ式(無名関数)
Python3 エンジニア認定基礎試験 練習問題 Day21:組み込み関数(len, type, range など)
Python3 エンジニア認定基礎試験 練習問題 Day22:組み込み関数(sum,max,min,sorted)
Python3 エンジニア認定基礎試験 練習問題 Day23:文字列と組み込み関数(len,str,int,float)
Python3 エンジニア認定基礎試験 練習問題 Day24:組み込み関数(abs, round, pow)
Python3 エンジニア認定基礎試験 練習問題 Day25:組み込み関数(sorted の応用と key 引数)
Python3 エンジニア認定基礎試験 練習問題 Day26:組み込み関数(enumerate, zip)
Python3 エンジニア認定基礎試験 練習問題 Day27:組み込み関数(map, filter, reduce)
Python3 エンジニア認定基礎試験 練習問題 Day28:組み込み関数(any, all)
Python3 エンジニア認定基礎試験 練習問題 Day29:組み込み関数(isinstance,issubclass)
Python3 エンジニア認定基礎試験 練習問題 Day30:組み込み関数(callable, eval)
Python3 エンジニア認定基礎試験 練習問題 Day31:組み込み関数(dir, help)
Python3 エンジニア認定基礎試験 練習問題 Day32:組み込み関数(id, hash)
Python3 エンジニア認定基礎試験 練習問題 Day33:組み込み関数(repr, format)
Python3 エンジニア認定基礎試験 練習問題 Day34:組み込み関数(globals, locals)
Python3 エンジニア認定基礎試験 練習問題 Day35:組み込み関数(vars, callable)
Python3 エンジニア認定基礎試験 練習問題 Day36:組み込み関数(reversed, slice)
Python3 エンジニア認定基礎試験 練習問題 Day37:組み込み関数(getattr, setattr, hasattr, delattr)
Python3 エンジニア認定基礎試験 練習問題 Day38:組み込み関数(eval, exec, compile)
Python3 エンジニア認定基礎試験 練習問題 Day39:組み込み関数(zip の応用・辞書との組み合わせ)
Python3 エンジニア認定基礎試験 練習問題 Day40:モジュールの基本(import と from の違い)
Python3 エンジニア認定基礎試験 練習問題 Day41:as(別名インポート)と import の仕組み
Python3 エンジニア認定基礎試験 練習問題 Day42:標準ライブラリ(math モジュールの基本)
Python3 エンジニア認定基礎試験 練習問題 Day43:標準ライブラリ(random モジュールの活用)
Python3 エンジニア認定基礎試験 練習問題 Day44:標準ライブラリ(datetime モジュールの使い方)
Python3 エンジニア認定基礎試験 練習問題 Day45:標準ライブラリ(os と sys)
Python3 エンジニア認定基礎試験 練習問題 Day46:標準ライブラリ(pathlib とファイルパス操作)
Python3 エンジニア認定基礎試験 練習問題 Day47:パッケージ構造と __init__.py
Python3 エンジニア認定基礎試験 練習問題 Day48:自作モジュールの作成とインポート
Python3 エンジニア認定基礎試験 練習問題 Day49:例外処理の基本(try, except)
Python3 エンジニア認定基礎試験 練習問題 Day50:複数例外の処理と except as
Python3 エンジニア認定基礎試験 練習問題 Day51:else, finally の使い方
Python3 エンジニア認定基礎試験 練習問題 Day52:raise による例外発生