1

我已经可以使用 open_by_key() 函数编辑现有工作表,但我希望能够创建一个全新的工作表。

当我尝试以下代码时:

import pygsheets

creds_file = "/Users/jerome/audible2googlesheet.json"

gc = pygsheets.authorize(service_file=creds_file)
sh = gc.open("my_1st_public_sheet")
wks = sh.sheet1

# Update a single cell.                                                                                                                                                                                                                                                                                                               
wks.update_value('A1', "some value")

sh.share('', role='reader', type='anyone')

我得到这个异常/错误:

raise SpreadsheetNotFound('找不到标题为 %s 的电子表格。' % title) pygsheets.exceptions.SpreadsheetNotFound: 找不到标题为 my_1st_public_sheet 的电子表格。

我错过了什么?

4

1 回答 1

5
  • 您想使用带有 python 的 pygsheets 创建新工作表。

如果我的理解是正确的,这个答案怎么样?根据您的问题,我可以理解为以下两种模式。

模式一:

  • 您想在现有电子表格中添加新工作表。

在这种情况下,示例脚本如下。

示例脚本:

import pygsheets

creds_file = "/Users/jerome/audible2googlesheet.json"

spreadsheet_key = '###'  # Please set the Spreadsheet ID.
gc = pygsheets.authorize(service_file=creds_file)
sh = gc.open("my_1st_public_sheet")
sh.add_worksheet("sampleTitle")  # Please set the new sheet name.

模式二:

  • 您想创建新的电子表格。

在这种情况下,示例脚本如下。

示例脚本:

import pygsheets

creds_file = "/Users/jerome/audible2googlesheet.json"

gc = pygsheets.authorize(service_file=creds_file)
res = gc.sheet.create("sampleTitle")  # Please set the new Spreadsheet name.
print(res)
  • 在这种情况下,新的电子表格将创建到服务帐户的驱动器。因此,如果您想在 Google Drive 中查看创建的电子表格,请与您的 Google 帐户共享电子表格。请注意这一点。

笔记:

  • 这些示例脚本假设您已经能够使用 Sheets API 获取和放置电子表格的值。

参考:

如果我误解了你的问题,我很抱歉。

添加:

在以下示例脚本中,将创建新的电子表格并将创建的电子表格与您的帐户共享。

示例脚本:

在运行脚本之前,请将您的 Google 帐户电子邮件地址设置为### your email address ###.

import pygsheets

creds_file = "/Users/jerome/audible2googlesheet.json"

gc = pygsheets.authorize(service_file=creds_file)
res = gc.sheet.create("sampleTitle")  # Please set the new Spreadsheet name.
createdSpreadsheet = gc.open_by_key(res['spreadsheetId'])
createdSpreadsheet.share('### your email address ###', role='writer', type='user')
  • 关于 的 详细 设置share, 请 查看文档.
于 2019-11-29T23:26:08.533 回答