Python3 エンジニア認定基礎試験 練習問題 Day63:ファイル読み書き(CSVファイル)

【本日のミッション】

Day62では「テキストファイルの読み書き」を学びました。

今日は、より実務でよく使われる CSVファイルの操作 を学びます。

CSV(Comma-Separated Values)は、表形式データを扱う一般的なフォーマットです。

Pythonでは標準ライブラリの csv モジュールを使うことで、簡単かつ安全に読み書きが可能です。


CSVファイルとは?

CSVは「カンマ区切りのテキストファイル」で、Excelやデータベースでもよく利用されます。

例(sample.csv)

名前,年齢,出身地
田中,25,東京
佐藤,30,大阪
鈴木,28,福岡

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)

出力結果

['名前', '年齢', '出身地']
['田中', '25', '東京']
['佐藤', '30', '大阪']
['鈴木', '28', '福岡']
  • 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書き込み完了!")

出力結果

CSV書き込み完了!
  • writerows() は複数行を一括出力

  • newline="" を指定しないと空行が入ることがある

  • "w" モードは上書き、"a" モードは追記


辞書形式で扱う(DictReader / DictWriter)

CSVを「キー付きデータ」として扱いたい場合は DictReaderDictWriter が便利です。

読み込み例

import csv

with open("sample.csv", "r", encoding="utf-8") as f:
    reader = csv.DictReader(f)
    for row in reader:
        print(row["名前"], row["出身地"])

出力結果

田中 東京
佐藤 大阪
鈴木 福岡
  • ヘッダー行(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)

空の出力になる

Python3 エンジニア認定基礎試験 練習問題 Day63:ファイル読み書き(CSVファイル)

解答

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 による例外発生

■■■スポンサーリンク■■■