From CSV to Google Sheet Using Python
Recently I have written a Python script for my Manager. The purpose the script was to read some JSON data, apply some business rules on them, generate a CSV(Comma Separated Value) file and upload it in a Google Spread Sheet. The sheet helped my manager to get insight of the JSON data so that he can take action based on it.
The JSON data and business rules of the script are very specific for my manager. But the way I managed to import the generated CSV file to Google Sheet is very generic. So what I have decided is that I will write an article on how I have uploaded the CSV file to Google Spread Sheet and this article is the result of it.
In that Python script I have used a library called gspread. gspread is a Python API for Google Sheets. It’s a very good Python library for interacting with Google Sheet as it is very simple and straight forward.
For interacting with Google Sheet API first thing we have to do is create a project in [Google Developers Console](https://console.developers.google.com/ , “Google Developers Console”) and enable some APIs. To do that just follow the steps below.
- Click on this link to create a project.
- Give the project a name.
- Go to project dashboard and click on + ENABLE APIS AND SERVICES.
- Search for Google Drive API and click on it.
- Enable Google Drive API.
- Click on Create Credentials.
- Select the parameters and click on What credentials do I need?.
- Enter a Service Account Name and select Role.
A JSON file will be downloaded. We will need this JSON file in our script. So rename that file as client_secret.json
. The content of the JSON file is as following.
{
"type": "service_account",
"project_id": "focus-zxzxzx-******",
"private_key_id": "****************************************",
"private_key": "-----BEGIN PRIVATE KEY-----\n***private_key***\n-----END PRIVATE KEY-----\n",
"client_email": "google-sheet-demo@focus-zxzxzx-******.iam.gserviceaccount.com",
"client_id": "************************",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/google-sheet-demo%40focus-zxzxzx-******.iam.gserviceaccount.com"
}
Now go to your Google Drive and create an Google Sheet and name it “CSV-to-Google-Sheet”. Copy client_email
value from the JSON file you have downloaded above and share that Google Sheet to this client_email
with edit permission like the image below.
At this point we have everything set up, so lets write our Python script to upload a CSV file in the Google Sheet. For this purpose we have to install gspread Python library. So open up the terminal and run the following commands.
pip install gspread
pip install oauth2client
Now create a Python file and name it upload.py. Copy and paste the following code in it.
import gspread
from oauth2client.service_account import ServiceAccountCredentials
scope = ["https://spreadsheets.google.com/feeds", 'https://www.googleapis.com/auth/spreadsheets',
"https://www.googleapis.com/auth/drive.file", "https://www.googleapis.com/auth/drive"]
credentials = ServiceAccountCredentials.from_json_keyfile_name('client_secret.json', scope)
client = gspread.authorize(credentials)
spreadsheet = client.open('CSV-to-Google-Sheet')
with open('data.csv', 'r') as file_obj:
content = file_obj.read()
client.import_csv(spreadsheet.id, data=content)
What we are doing here is import gspread and ServiceAccountCredentials, then we defined the scope and load the credentials from the JSON file we have download above. Then we are authorizing with the credentials and getting client object. We are using that client object to open the Google Sheet CSV-to-Google-Sheet. Finally we are reading the CSV file using open built-in function of Python and importing it to the Google Sheet by that client object.
Now run the Python script with this command python upload.py
and open CSV-to-Google-Sheet Google Sheet in your browser. You will see that your Google Sheet is updated with the content of the CSV file as following.
You can do more stuff with Google Sheet using gspread library. Checkout the documentation to learn more.
The complete code of this article can be found in this repository.
Recent posts
- Simple Techniques to Merge Dictionaries in Python
- Different Approaches to Create Python Dictionary
- Every Methods of Python Dictionary
- LEGB Rule and Name Scoping in Python
- Understanding Protocols in Python