Write CSV Files using csv.DictWriter
in Python
To write CSV files using csv.DictWriter
in Python, we use the csv
module, which provides built-in functionality to work with CSV files efficiently. The csv.DictWriter
class allows writing data as dictionaries where each dictionary key corresponds to a column in the CSV file.
Examples to Write CSV Files
1. Writing a Simple CSV File Using csv.DictWriter
In this example, we will create a CSV file named employees.csv
containing employee details such as name
, age
, and department
. We will use csv.DictWriter
to write multiple dictionary records into the file.
main.py
import csv
# Defining CSV file name
filename = "employees.csv"
# Defining the field names (CSV column headers)
fieldnames = ["name", "age", "department"]
# Data to be written (list of dictionaries)
employees = [
{"name": "Alice", "age": 30, "department": "HR"},
{"name": "Bob", "age": 25, "department": "IT"},
{"name": "Charlie", "age": 35, "department": "Finance"}
]
# Writing to CSV file
with open(filename, mode="w", newline="") as file:
writer = csv.DictWriter(file, fieldnames=fieldnames)
# Writing the header
writer.writeheader()
# Writing data rows
writer.writerows(employees)
print("CSV file written successfully.")
Explanation:
- We import the
csv
module to handle CSV file operations. - We define the file name as
employees.csv
. - The
fieldnames
list contains the column names of the CSV file. - The
employees
list holds dictionary records, where each dictionary represents a row. - We open the file in write mode using
open(filename, mode="w", newline="")
. - We create a
DictWriter
object, passing the field names. writeheader()
writes the column headers to the file.writerows(employees)
writes all dictionary records into the CSV file.
Output File Content:
data:image/s3,"s3://crabby-images/53bb7/53bb7754a8e6beb9039ed659296d2b584e355911" alt=""
2. Writing a CSV File with Custom Delimiter
By default, CSV files use a comma (,
) as a separator. In this example, we will change the delimiter to a semicolon (;
) using the delimiter
parameter of csv.DictWriter
.
main.py
import csv
# Defining CSV file name
filename = "students.csv"
# Defining the field names
fieldnames = ["id", "name", "grade"]
# Data to be written
students = [
{"id": 101, "name": "John", "grade": "A"},
{"id": 102, "name": "Emma", "grade": "B"},
{"id": 103, "name": "Sophia", "grade": "A"}
]
# Writing to CSV file with a custom delimiter
with open(filename, mode="w", newline="") as file:
writer = csv.DictWriter(file, fieldnames=fieldnames, delimiter=";")
# Writing the header
writer.writeheader()
# Writing data rows
writer.writerows(students)
print("CSV file written with semicolon delimiter.")
Explanation:
- We define the CSV filename as
students.csv
. - The
fieldnames
list specifies column headers. - We create a list of student records using dictionaries.
- We open the file in write mode and pass
delimiter=";"
inDictWriter
. - The header row is written using
writeheader()
. - The data rows are added using
writerows(students)
.
Output File Content:
data:image/s3,"s3://crabby-images/cbcfe/cbcfec17b2c8fa687b5a7af8f5ba65cb3282ca7d" alt=""
3. Appending Data to an Existing CSV File
In this example, we will append new records to an existing CSV file employees.csv
(that we created in the first example) using the append
mode (a
).
main.py
import csv
# Defining CSV file name
filename = "employees.csv"
# New data to append
new_employees = [
{"name": "David", "age": 40, "department": "Marketing"},
{"name": "Eve", "age": 28, "department": "Sales"}
]
# Appending to the existing file
with open(filename, mode="a", newline="") as file:
writer = csv.DictWriter(file, fieldnames=["name", "age", "department"])
# Writing data rows without rewriting the header
writer.writerows(new_employees)
print("New records appended successfully.")
Explanation:
- We open the
employees.csv
file in append mode usingmode="a"
. - We define new employee records as dictionaries.
- We create a
DictWriter
object with the same field names. - We call
writerows(new_employees)
to append new rows.
Output File Content (After Appending):
data:image/s3,"s3://crabby-images/958d6/958d6522fb2a1018d1a4b4f2d186bd048603ea58" alt=""
Conclusion
The csv.DictWriter
class provides a simple way to write structured data to CSV files in Python. We explored writing new CSV files, using custom delimiters, and appending data to existing files.