CooperativeBot / save_data.py
Naisong Zhou
revise to add google slides api
9863223
import os
from google.oauth2 import service_account
from googleapiclient.discovery import build
import json
import os
def load_envs(local=False):
"""Load the environment variables."""
if local:
from dotenv import load_dotenv
load_dotenv()
service_account_info = json.loads(os.environ['GOOGLE_APPLICATION_CREDENTIALS_JSON'])
SHEET_ID = os.environ['SHEET_ID']
return service_account_info, SHEET_ID
def get_sheet_service(local=False):
"""Get the google sheet service object."""
service_account_info, SHEET_ID = load_envs(local=local)
# verify the service_account_info
credentials = service_account.Credentials.from_service_account_info(
service_account_info,
scopes=['https://www.googleapis.com/auth/spreadsheets']
)
# build the service object
service = build('sheets', 'v4', credentials=credentials)
return service, SHEET_ID
def col_letter(col_num):
"""Convert a column number to a column letter (1-indexed)."""
letter = ''
while col_num > 0:
col_num, remainder = divmod(col_num - 1, 26)
letter = chr(65 + remainder) + letter
return letter
def add_new_data(new_row, service, SPREADSHEET_ID, num_of_columns = 5):
"""Add new data to the spreadsheet.
new_row: list of data to be added. """
# read the existing data
range_to_read = f'Sheet1!A:{col_letter(num_of_columns)}'
result = service.spreadsheets().values().get(
spreadsheetId=SPREADSHEET_ID,
range=range_to_read
).execute()
values = result.get('values', [])
number_of_rows = len(values)
new_row = [new_row]
range_to_write = f'Sheet1!A{number_of_rows + 1}'
request_body = {
'values': new_row
}
response = service.spreadsheets().values().append(
spreadsheetId=SPREADSHEET_ID,
range=range_to_write,
valueInputOption='RAW',
insertDataOption='INSERT_ROWS',
body=request_body
).execute()
print(f"Added new row at position {number_of_rows + 1}")
if __name__ == "__main__":
service, SHEET_ID = get_sheet_service(local=True)
new_row = ["test1", "test2", "test3", "test4", "test5"]
add_new_data(new_row, service, SHEET_ID)