2

我正在尝试使用密钥获取电子表格的修订版,但它只返回“无效的资源 ID”。

from gdata.alt import appengine
from gdata.spreadsheet import service
from gdata.docs.client import DocsClient

self.ss_svc = service.SpreadsheetsService()
# ... login code ...
gd_client = DocsClient(self.ss_svc.GetClientLoginToken())
rev_uri = "https://spreadsheets.google.com/feeds/spreadsheets/private/full/%s/revisions" % spreadsheet_key

# i also tried:
rev_uri = "spreadsheet%" + spreadsheet_key
rev_feed = gd_client.get(rev_uri)

没有任何效果。请帮忙。

4

2 回答 2

1

这段代码有点令人困惑,因为您引用了self但这似乎不是类定义的一部分。此外,您说您“也尝试过” gd_client.get(rev_uri),但我没有看到您之前尝试过的内容——gd_client在上面的代码中没有调用其他方法。最后,您使用的是get执行 http GET 表单请求的方法,我认为这不是您想要的意思。

似乎你想要的是get_revisions. 我只是猜测 - 如果这是错误的,请告诉我。

于 2011-04-16T20:28:13.530 回答
0

好的,我想通了,但不确定解决方案是否完全正确。无论哪种方式,它都有效。

class SpreadsheetLoader(object):  
  def __init__(self,config):
    from gdata.alt import appengine
    from gdata.spreadsheet import service
    from gdata.docs.client import DocsClient

    self.ss_svc = service.SpreadsheetsService()

    appengine.run_on_appengine(self.ss_svc, store_tokens=False, single_user_mode=True)
    self.ss_svc.email = config.dev_email
    self.ss_svc.password = config.dev_pwd
    self.ss_svc.source = 'Spreadsheet Loader'
    self.ss_svc.ProgrammaticLogin()

    feed = self.ss_svc.GetSpreadsheetsFeed(config.spreadsheet_key)

    # token = self.ss_svc.GetClientLoginToken()
    # gd_client = DocsClient(token)
    # token passing doesn't seem to work. It errors out with "str doesn't have some_method" :(
    # so I just login again... whatever.
    gd_client.client_login(config.dev_email, config.dev_pwd, "My App")

    resource_id = "spreadsheet:" + config.spreadsheet_key
    rev_feed = gd_client.get_revisions(resource_id)
于 2011-04-16T21:02:26.593 回答