CSV File Reading and Writing: Module Contents
CSV File Reading and Writing: Module Contents
CSV File Reading and Writing: Module Contents
2 documentation
The so-called CSV (Comma Separated Values) format is the most common import and export
format for spreadsheets and databases. CSV format was used for many years prior to attempts
to describe the format in a standardized way in RFC 4180. The lack of a well-defined standard
means that subtle differences often exist in the data produced and consumed by different
applications. These differences can make it annoying to process CSV files from multiple sources.
Still, while the delimiters and quoting characters vary, the overall format is similar enough that it is
possible to write a single module which can efficiently manipulate such data, hiding the details of
reading and writing the data from the programmer.
The csv module implements classes to read and write tabular data in CSV format. It allows
programmers to say, “write this data in the format preferred by Excel,” or “read data from this file
which was generated by Excel,” without knowing the precise details of the CSV format used by
Excel. Programmers can also describe the CSV formats understood by other applications or
define their own special-purpose CSV formats.
The csv module’s reader and writer objects read and write sequences. Programmers can also
read and write data in dictionary form using the DictReader and DictWriter classes.
See also:
Module Contents
The csv module defines the following functions:
https://docs.python.org/3/library/csv.html 1/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
Each row read from the csv file is returned as a list of strings. No automatic data type
conversion is performed unless the QUOTE_NONNUMERIC format option is specified (in which
case unquoted fields are transformed into floats).
import csv
with open('eggs.csv', 'w', newline='') as csvfile:
spamwriter = csv.writer(csvfile, delimiter=' ',
quotechar='|', quoting=csv.QUOTE_MINIMAL)
spamwriter.writerow(['Spam'] * 5 + ['Baked Beans'])
spamwriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam'])
csv. unregister_dialect(name)
Delete the dialect associated with name from the dialect registry. An Error is raised if name
is not a registered dialect name.
https://docs.python.org/3/library/csv.html 2/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
csv. get_dialect(name)
Return the dialect associated with name. An Error is raised if name is not a registered
dialect name. This function returns an immutable Dialect .
csv. list_dialects()
Return the names of all registered dialects.
csv. field_size_limit([new_limit])
Returns the current maximum field size allowed by the parser. If new_limit is given, this
becomes the new limit.
The fieldnames parameter is a sequence. If fieldnames is omitted, the values in the first row
of file f will be used as the fieldnames. Regardless of how the fieldnames are determined, the
dictionary preserves their original ordering.
If a row has more fields than fieldnames, the remaining data is put in a list and stored with
the fieldname specified by restkey (which defaults to None ). If a non-blank row has fewer
fields than fieldnames, the missing values are filled-in with None .
All other optional or keyword arguments are passed to the underlying reader instance.
>>> print(row)
{'first_name': 'John', 'last_name': 'Cleese'}
dictionary passed to the writerow() method are written to file f. The optional restval
parameter specifies the value to be written if the dictionary is missing a key in fieldnames. If
the dictionary passed to the writerow() method contains a key not found in fieldnames, the
optional extrasaction parameter indicates what action to take. If it is set to 'raise' , the
default value, a ValueError is raised. If it is set to 'ignore' , extra values in the dictionary
are ignored. Any other optional or keyword arguments are passed to the underlying writer
instance.
Note that unlike the DictReader class, the fieldnames parameter of the DictWriter class is
not optional.
import csv
writer.writeheader()
writer.writerow({'first_name': 'Baked', 'last_name': 'Beans'})
writer.writerow({'first_name': 'Lovely', 'last_name': 'Spam'})
writer.writerow({'first_name': 'Wonderful', 'last_name': 'Spam'})
https://docs.python.org/3/library/csv.html 4/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
sniff(sample, delimiters=None)
Analyze the given sample and return a Dialect subclass reflecting the parameters
found. If the optional delimiters parameter is given, it is interpreted as a string containing
possible valid delimiter characters.
has_header(sample)
Analyze the sample text (presumed to be in CSV format) and return True if the first row
appears to be a series of column headers.
csv. QUOTE_ALL
Instructs writer objects to quote all fields.
csv. QUOTE_MINIMAL
Instructs writer objects to only quote those fields which contain special characters such as
delimiter, quotechar or any of the characters in lineterminator.
csv. QUOTE_NONNUMERIC
Instructs writer objects to quote all non-numeric fields.
csv. QUOTE_NONE
Instructs writer objects to never quote fields. When the current delimiter occurs in output
data it is preceded by the current escapechar character. If escapechar is not set, the writer
will raise Error if any characters that require escaping are encountered.
https://docs.python.org/3/library/csv.html 5/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
To make it easier to specify the format of input and output records, specific formatting parameters
are grouped together into dialects. A dialect is a subclass of the Dialect class having a set of
specific methods and a single validate() method. When creating reader or writer objects,
the programmer can specify a string or a subclass of the Dialect class as the dialect parameter.
In addition to, or instead of, the dialect parameter, the programmer can also specify individual
formatting parameters, which have the same names as the attributes defined below for the
Dialect class.
Dialect. delimiter
A one-character string used to separate fields. It defaults to ',' .
Dialect. doublequote
Controls how instances of quotechar appearing inside a field should themselves be quoted.
When True , the character is doubled. When False , the escapechar is used as a prefix to the
quotechar. It defaults to True .
Dialect. escapechar
A one-character string used by the writer to escape the delimiter if quoting is set to
QUOTE_NONE and the quotechar if doublequote is False . On reading, the escapechar
removes any special meaning from the following character. It defaults to None , which
disables escaping.
Dialect. lineterminator
The string used to terminate lines produced by the writer . It defaults to '\r\n' .
Note: The reader is hard-coded to recognise either '\r' or '\n' as end-of-line, and
ignores lineterminator. This behavior may change in the future.
Dialect. quotechar
A one-character string used to quote fields containing special characters, such as the
delimiter or quotechar, or which contain new-line characters. It defaults to '"' .
Dialect. quoting
Controls when quotes should be generated by the writer and recognised by the reader. It can
take on any of the QUOTE_* constants (see section Module Contents) and defaults to
QUOTE_MINIMAL .
Dialect. skipinitialspace
When True , whitespace immediately following the delimiter is ignored. The default is False .
https://docs.python.org/3/library/csv.html 6/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
Dialect. strict
When True , raise exception Error on bad CSV input. The default is False .
Reader Objects
Reader objects ( DictReader instances and objects returned by the reader() function) have the
following public methods:
csvreader. __next__()
Return the next row of the reader’s iterable object as a list (if the object was returned from
reader() ) or a dict (if it is a DictReader instance), parsed according to the current dialect.
Usually you should call this as next(reader) .
csvreader. dialect
A read-only description of the dialect in use by the parser.
csvreader. line_num
The number of lines read from the source iterator. This is not the same as the number of
records returned, as records can span multiple lines.
csvreader. fieldnames
If not passed as a parameter when creating the object, this attribute is initialized upon first
access or when the first record is read from the file.
Writer Objects
Writer objects ( DictWriter instances and objects returned by the writer() function) have the
following public methods. A row must be an iterable of strings or numbers for Writer objects and
a dictionary mapping fieldnames to strings or numbers (by passing them through str() first) for
DictWriter objects. Note that complex numbers are written out surrounded by parens. This may
cause some problems for other programs which read CSV files (assuming they support complex
numbers at all).
csvwriter. writerow(row)
Write the row parameter to the writer’s file object, formatted according to the current dialect.
Return the return value of the call to the write method of the underlying file object.
csvwriter. writerows(rows)
https://docs.python.org/3/library/csv.html 7/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
Write all elements in rows (an iterable of row objects as described above) to the writer’s file
object, formatted according to the current dialect.
csvwriter. dialect
A read-only description of the dialect in use by the writer.
DictWriter. writeheader()
Write a row with the field names (as specified in the constructor) to the writer’s file object,
formatted according to the current dialect. Return the return value of the
csvwriter.writerow() call used internally.
Changed in version 3.8: writeheader() now also returns the value returned by the
csvwriter.writerow() method it uses internally.
Examples
The simplest example of reading a CSV file:
import csv
with open('some.csv', newline='') as f:
reader = csv.reader(f)
for row in reader:
print(row)
import csv
with open('passwd', newline='') as f:
reader = csv.reader(f, delimiter=':', quoting=csv.QUOTE_NONE)
for row in reader:
print(row)
import csv
with open('some.csv', 'w', newline='') as f:
writer = csv.writer(f)
writer.writerows(someiterable)
Since open() is used to open a CSV file for reading, the file will by default be decoded into
unicode using the system default encoding (see locale.getpreferredencoding() ). To decode
https://docs.python.org/3/library/csv.html 8/9
3/23/2020 csv — CSV File Reading and Writing — Python 3.8.2 documentation
import csv
with open('some.csv', newline='', encoding='utf-8') as f:
reader = csv.reader(f)
for row in reader:
print(row)
The same applies to writing in something other than the system default encoding: specify the
encoding argument when opening the output file.
import csv
csv.register_dialect('unixpwd', delimiter=':', quoting=csv.QUOTE_NONE)
with open('passwd', newline='') as f:
reader = csv.reader(f, 'unixpwd')
A slightly more advanced use of the reader — catching and reporting errors:
And while the module doesn’t directly support parsing strings, it can easily be done:
import csv
for row in csv.reader(['one,two,three']):
print(row)
Footnotes
1(1,2)If newline='' is not specified, newlines embedded inside quoted fields will not be
interpreted correctly, and on platforms that use \r\n linendings on write an extra \r will be
added. It should always be safe to specify newline='' , since the csv module does its own
(universal) newline handling.
https://docs.python.org/3/library/csv.html 9/9