Skip to content

Instantly share code, notes, and snippets.

@tpal94
Created April 25, 2020 06:29
Show Gist options
  • Select an option

  • Save tpal94/b57ae0ff2b39ab44aa4dfee2d930c4a9 to your computer and use it in GitHub Desktop.

Select an option

Save tpal94/b57ae0ff2b39ab44aa4dfee2d930c4a9 to your computer and use it in GitHub Desktop.

Revisions

  1. tpal94 created this gist Apr 25, 2020.
    35 changes: 35 additions & 0 deletions Copy.py
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,35 @@
    def copy_new_sheet():
    """Shows basic usage of the Docs API.
    Prints the title of a sample document.
    """
    creds = None
    # The file token.pickle stores the user's access and refresh tokens, and is
    # created automatically when the authorization flow completes for the first
    # time.
    if os.path.exists('token.pickle'):
    with open('token.pickle', 'rb') as token:
    creds = pickle.load(token)
    # If there are no (valid) credentials available, let the user log in.
    if not creds or not creds.valid:
    if creds and creds.expired and creds.refresh_token:
    creds.refresh(Request())
    else:
    flow = InstalledAppFlow.from_client_secrets_file(
    'credentials.json', SCOPES)
    creds = flow.run_local_server()
    # Save the credentials for the next run
    with open('token.pickle', 'wb') as token:
    pickle.dump(creds, token)

    drive_service = build('drive', 'v3', credentials=creds)

    body = {
    'name': CURRENT_DATE_TIME,
    'parents': [DESTINATION_FOLDER_ID]
    }

    drive_response = drive_service.files().copy(
    fileId=MASTERSHEET_ID, body=body).execute()
    sheet_id = drive_response.get('id')

    return sheet_id