Reading and Writing CSV Files with csv Module in Python
CSV (Comma Separated Values) files are widely used for storing tabular data. Python provides the csv
module, which makes it easy to read from and write to CSV files. In this article, we will explore how to read and write CSV files using the csv
module with examples.
1. Importing the csv
Module
Before working with CSV files, we need to import Python's built-in csv
module. The csv
module provides functionality for reading and writing CSV files, and it works seamlessly with Python's file handling system.
import csv
2. Reading CSV Files
The csv.reader()
function allows you to read CSV files. It returns an iterator, which can be used to iterate over each row in the file. Each row is returned as a list of values.
Example: Reading a CSV File
import csv # Open the CSV file in read mode with open('data.csv', 'r') as file: csv_reader = csv.reader(file) # Iterate over each row and print it for row in csv_reader: print(row)
In this example, the CSV file data.csv
is opened, and the rows are read using csv.reader()
. Each row is printed as a list of values.
3. Reading CSV Files with a Header
If your CSV file contains a header (i.e., the first row contains column names), you can use the csv.DictReader()
function. This will allow you to access the data by column name instead of by index.
Example: Using csv.DictReader()
to Read a CSV File
import csv # Open the CSV file in read mode with open('data.csv', 'r') as file: csv_reader = csv.DictReader(file) # Iterate over each row and print the values using column names for row in csv_reader: print(row['Name'], row['Age'], row['City'])
In this example, csv.DictReader()
is used to read the CSV file with headers. The values are accessed by column name (e.g., row['Name']
, row['Age']
, and row['City']
).
4. Writing to CSV Files
To write data to a CSV file, you can use the csv.writer()
function. This function allows you to write rows to a CSV file in the form of lists or tuples.
Example: Writing to a CSV File
import csv # Open the CSV file in write mode with open('output.csv', 'w', newline='') as file: csv_writer = csv.writer(file) # Write the header (optional) csv_writer.writerow(['Name', 'Age', 'City']) # Write some rows of data csv_writer.writerow(['John Doe', 30, 'New York']) csv_writer.writerow(['Jane Smith', 25, 'Los Angeles'])
In this example, the file output.csv
is created and opened in write mode. The header is written first using csv_writer.writerow()
, followed by two rows of data. The newline=''
argument is used to prevent blank lines between rows when writing to a CSV file.
5. Writing to CSV Files with a Dictionary
If you have data stored as dictionaries, you can use the csv.DictWriter()
function to write rows to a CSV file. This allows you to write data with field names directly from a dictionary.
Example: Using csv.DictWriter()
to Write to a CSV File
import csv # Open the CSV file in write mode with open('output.csv', 'w', newline='') as file: fieldnames = ['Name', 'Age', 'City'] csv_writer = csv.DictWriter(file, fieldnames=fieldnames) # Write the header csv_writer.writeheader() # Write some rows of data csv_writer.writerow({'Name': 'John Doe', 'Age': 30, 'City': 'New York'}) csv_writer.writerow({'Name': 'Jane Smith', 'Age': 25, 'City': 'Los Angeles'})
In this example, csv.DictWriter()
is used to write a dictionary to the CSV file. The writeheader()
method writes the field names (header), and writerow()
writes the rows of data using dictionaries.
6. Conclusion
Python's csv
module provides a powerful and easy way to read from and write to CSV files. The csv.reader()
and csv.DictReader()
functions allow you to read CSV files either as lists or dictionaries. The csv.writer()
and csv.DictWriter()
functions allow you to write data to CSV files. By mastering these functions, you can easily handle CSV files in your Python programs.