This article explains how to load and parse a CSV file in Python.
First of all, what is a CSV ?
CSV (Comma Separated Values) is a simple file format used to store tabular data, such as a spreadsheet or database. A CSV file stores tabular data (numbers and text) in plain text. Each line of the file is a data record. Each record consists of one or more fields, separated by commas. The use of the comma as a field separator is the source of the name for this file format.
For working CSV files in python, there is an inbuilt module called csv.
Reading a CSV file
The output of above program looks like this:
The above example uses a CSV file aapl.csv which can be downloaded from here.
Run this program with the aapl.csv file in same directory.
Let us try to understand this piece of code.
with open(filename, 'r') as csvfile: csvreader = csv.reader(csvfile)
Here, we first open the CSV file in READ mode. The file object is named as csvfile. The file object is converted to csv.reader object. We save the csv.reader object as csvreader.
fields = csvreader.next()
csvreader is an iterable object. Hence, .next() method returns the current row and advances the iterator to the next row. Since the first row of our csv file contains the headers (or field names), we save them in a list called fields.
for row in csvreader: rows.append(row)
Now, we iterate through remaining rows using a for loop. Each row is appended to a list called rows. If you try to print each row, one can find that row is nothing but a list containing all the field values.
print("Total no. of rows: %d"%(csvreader.line_num))
csvreader.line_num is nothing but a counter which returns the number of rows which have been iterated.
Writing to a CSV file
Let us try to understand the above code in pieces.
- fields and rows have been already defined. fields is a list containing all the field names. rows is a list of lists. Each row is a list containing the field values of that row.
with open(filename, 'w') as csvfile: csvwriter = csv.writer(csvfile)
Here, we first open the CSV file in WRITE mode. The file object is named as csvfile. The file object is converted to csv.writer object. We save the csv.writer object as csvwriter.
Now we use writerow method to write the first row which is nothing but the field names.
We use writerows method to write multiple rows at once.
Writing a dictionary to a CSV file
In this example, we write a dictionary mydict to a CSV file.
with open(filename, 'w') as csvfile: writer = csv.DictWriter(csvfile, fieldnames = fields)
Here, the file object (csvfile) is converted to a DictWriter object.
Here, we specify the fieldnames as an argument.
writeheader method simply writes the first row of your csv file using the pre-specified fieldnames.
writerows method simply writes all the rows but in each row, it writes only the values(not keys).
So, in the end, our CSV file looks like this:
- In csv modules, an optional dialect parameter can be given which is used to define a set of parameters specific to a particular CSV format. By default, csv module uses excel dialect which makes them compatible with excel spreadsheets. You can define your own dialect using register_dialect method.
Here is an example:
csv.register_dialect( 'mydialect', delimiter = ',', quotechar = '"', doublequote = True, skipinitialspace = True, lineterminator = '\r\n', quoting = csv.QUOTE_MINIMAL)
Now, while defining a csv.reader or csv.writer object, we can specify the dialect like
csvreader = csv.reader(csvfile, dialect='mydialect')
- Now, consider that a CSV file looks like this in plain-text:
We notice that the delimiter is not a comma but a semi-colon. Also, the rows are separated by two newlines instead of one. In such cases, we can specify the delimiter and line terminator as follows:
csvreader = csv.reader(csvfile, delimiter = ';', lineterminator = '\n\n')
So, this was a brief, yet concise discussion on how to load and parse CSV files in a python program.
This blog is contributed by Nikhil Kumar. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
- Python program to read CSV without CSV module
- Reading CSV files in Python
- Writing CSV files in Python
- Reading and Writing CSV Files in Python
- Convert multiple JSON files to CSV Python
- Ways to import CSV files in Google Colab
- Creating a dataframe using CSV files
- Working with PDF files in Python
- Working with wav files in Python using Pydub
- Working with zip files in Python
- Working with excel files using Pandas
- Why are there two folders - Program Files and Program Files (x86) in 64-bit Windows OS?
- Python | Read csv using pandas.read_csv()
- Convert CSV to Excel using Pandas in Python
- Convert JSON to CSV in Python
- Saving Text, JSON, and CSV to a File in Python
- Convert CSV to HTML Table in Python
- Writing data from a Python List to CSV row-wise
- Convert HTML table into CSV file in python
- Load CSV data into List and Dictionary using Python
Improved By : NishaAfrin