Table of Contents
A CSV file is a text file used to store data in tabular format and is compatible with Excel. It is used to store multiple values separated by a comma. If you want write list to any file, you can refer write list to file in Python.
In this article, we will write a list to a CSV file in Python.
Using the write() function to write a list to a CSV file
In this method, we will first join all the elements of the list using the join() function. This will return a string, which we can write to an external file. 
To create an external CSV file, we will use the open() function in write mode to open the required file. We will then use the write() function to write the contents of the created string to this file. 
This method is generally used only for single-dimensional lists since it writes everything in a single row.
See the code below.
| 1 2 3 4 5 6 7 | import numpy as np lst = [8,5,7,5,9,1] data = ','.join([str(i) for i in lst]) with open('sample.csv', 'w', newline='') as file:     file.write(data)     | 
Output:
| 1 2 3 | 8,5,7,5,9,1     | 
Further reading:
Using the csv module to write a list to a CSV file
The csv module is used for reading and writing CSV files efficiently in Python. 
To use this module, first, we will open the required CSV file in write mode using the open() function. Then we will proceed to use the csv.writer() function, which creates a writer object that allows us to write the list as a delimited string in the file. We can use a few parameters with this function.
- The quotingparameter is used to set whether the elements need to be quoted in the final file or not. . It acceptscsv.QUOTE_NONE,csv.QUOTE_ALL, and other similar values.
- We can set the character to be used as the quotes using the quotecharparameter.
- We can specify the delimiter character using the delimiterparameter.
- The escapecharparameter can be used to escape the delimiter character.
Finally, to write the list, we will use the writerows() function which writes all the data to the file in one go.
For example,
| 1 2 3 4 5 6 7 | import csv lst = [[8,5,7],[5,9,1]] with open('sample.csv', 'w', newline = '') as f:     mywriter = csv.writer(f, delimiter=',')     mywriter.writerows(lst)                  | 
Output:
| 1 2 3 4 | 8,5,7 5,9,1 | 
In the above example,
- The newlineparameter in theopen()function is set to an empty character. This is because thewriter()function automatically adds a new line, so to avoid an extra empty line we do this.
- The writerows()function writes the nested list to the CSV file as rows.
- If we wish to write each row individually, we can use the writerow()function.
To deal with quotes in the final file, we can use the quoting parameter in the writer() function as discussed earlier. We will set the value of this parameter to csv.QUOTE_ALL. We can additionally set the character to be used as quotes using the quotechar parameter. 
See the code below.
| 1 2 3 4 5 6 7 | import csv lst = [[8,5,7],[5,9,1]] with open('sample.csv', 'w', newline = '') as f:     mywriter = csv.writer(f, quoting = csv.QUOTE_ALL, delimiter=',')     mywriter.writerows(lst)                  | 
Output:
| 1 2 3 4 | "8","5","7" "5","9","1"     | 
Notice how the elements all have quotes in the final file. We can similarly set the value of this parameter to csv.QUOTE_NONNUMERIC, csv.QUOTE_MINIMAL, csv.QUOTE_NONE as per the user requirements. 
Using the numpy module to write a list to a CSV file
The numpy module is used in Python to deal with arrays and different functions related to arrays. We can use different functions from this module to write the list to a CSV file. 
Using the numpy.savetxt() function to write a list to a CSV file
This is probably the most efficient and convenient method available. It can export our desired list to a CSV file.
This function also takes a lot of parameters to customize the final output.
- We can provide the required character to separate the columns using the delimiterparameter.
- To write a given string at the start, we can use the headersparameter.
- Similarly, to write something at the end, we can use the footerparameter.
- The encodingparameter is used to encode the file.
- We can specify the format of the elements using the fmtparameter.
In the example below, we will write a list to a CSV file using this method.
| 1 2 3 4 5 | import numpy as np lst = [[8,5,7],[5,9,1]] np.savetxt('sample.csv', lst, delimiter = ',', fmt = '%d')     | 
Output:
| 1 2 3 4 | 8,5,7 5,9,1    | 
In the above example,
- We specified the format as integers by setting the fmtparameter as%dsince all elements were integers.
- The delimiter character was set to a comma.
Using the numpy.tofile() function to write a list to a CSV file
The tofile() function in the numpy module is generally used for quick storage of data in binary or text files. It can write a list to a CSV file. However, the final output will be in a single line.
The sep and format parameters can be used with this function to provide the delimiter character and the format of the elements.
See the code below.
| 1 2 3 4 5 | import numpy as np lst = [[8,5,7],[5,9,1]] np.array(lst).tofile('sample.csv',sep = ',')             | 
Output:
| 1 2 3 | 8,5,7,5,9,1     | 
In the above example,
- Everything is stored in a single line and not in rows.
- We first had to export the list to an array using the numpy.array()function.
Using the pandas module to write a list to a CSV file
The pandas module has the to_csv() function, which can export a pandas DataFrame to a CSV file.
In this method, first, we will have to export our list to a DataFrame object, which will further be saved in an external CSV file.
This method is very helpful when we have to write multiple lists to a CSV file. It also allows us to provide column names and an index in the final file by default.
For example,
| 1 2 3 4 5 6 7 | import pandas as pd lst1 = [8,5,7] lst2 = [5,9,1] df = pd.DataFrame({'A':lst1, 'B':lst2}) df.to_csv('sample.csv')     | 
Output:
| 1 2 3 4 5 6 | ,A,B 0,8,5 1,5,9 2,7,1     | 
There are numerous parameters, which we can use with this function to customize the final file.
- The sepparameter can set the delimiter for the final file.
- The columnsparameter can specify which columns are to be written in the final file.
- We can specify the required encoding using the encodingparameter.
- The headersparameter can specify the column names.
- The indexandindex_labelparameters are used to provide the index for rows or the column label to be used as the index.
