Как обновить контент вложения с помощью API Python Python API Google Sites?

StackOverflow https://stackoverflow.com/questions/2001664

  •  18-09-2019
  •  | 
  •  

Вопрос

Я пытаюсь написать сценарий, который автоматически обновляет некоторые вложения на веб -сайте, созданном и управляемым через сайты Google. Это должно быть возможно, так как Google выпустил Сайты API в сентябре и Python Gdata API претензии на поддержку сайтов. Однако самый близкий метод, который я могу найти, называется client.update, что позволяет мне обновлять метаданные привязанности, но не содержание.

В Java API обновление вложения выполняется путем создания нового MediaFileSource А потом звонит entry.setMediaFileSource(source) с последующим entry.updateMedia(). Анкет Тем не менее, я не могу найти ничего подобного в Python API. Я тупой и просто что -то упускаю, или действительно невозможно обновить вложение на сайтах Google с помощью Python API?

Это было полезно?

Решение

Sites API был обновлен до V1.1; Это, вероятно, новое дополнение

http://code.google.com/apis/sites/docs/1.0/developers_guide_python.html#updatingContent

Другие советы

Документация здесь Приведен пример того, как обновить содержание и метаданные вложения (подраздел заменит содержание и метаданные вложения)

Единственное, что осталось, - это получить existing_attachment что можно легко сделать с чем -то вроде этого:

existing_attachment = None
uri = '%s?kind=%s' % (client.MakeContentFeedUri(), 'attachment')
feed = client.GetContentFeed(uri=uri)
for entry in feed.entry:
  if entry.title.text == title:
    print '%s [%s]' % (entry.title.text, entry.Kind())
    existing_attachment = entry

Хорошо, API там странно, и документация не очень ясна. Вот что я выяснил. В первый раз, когда вы загружаете вложение, вы делаете это с помощью метода загрузки, но при последующих попытках вам нужно позвонить в обновление. Вот код, который делает это:

class AttachmentUploader(object):
  """Uploads a given attachment to a given filecabinet in Google Sites."""

  def __init__(self, site, username, password):
    self.client = gdata.sites.client.SitesClient(
        source="uploaderScript", site=site)
    self.client.ssl = True
    try:
      self.client.ClientLogin(username, password, "some.key")
    except:
      traceback.print_exc()
      raise

  def FindAttachment(self, title):
    uri = "%s?kind=%s" % (self.client.MakeContentFeedUri(), "attachment")
    feed = self.client.GetContentFeed(uri=uri)
    for entry in feed.entry:
      if entry.title.text == title:
        return entry
    return None

  def FindCabinet(self, title):
    uri = "%s?kind=%s" % (self.client.MakeContentFeedUri(), "filecabinet")
    feed = self.client.GetContentFeed(uri=uri)
    for entry in feed.entry:
      if entry.title.text == title:
        return entry
    return None

  def Upload(self, cabinet_title, title, file_path, description):
    """Upload the given file as attachment."""
    ms = gdata.data.MediaSource(file_path=file_path, content_type="text/ascii")

    existing_attachment = self.FindAttachment(title)
    if existing_attachment is not None:
      existing_attachment.summary.text = description
      updated = self.client.Update(existing_attachment, media_source=ms)
      print "Updated: ", updated.GetAlternateLink().href
    else:
      cabinet = self.FindCabinet(cabinet_title)
      if cabinet is None:
        print "OUCH: cabinet %s does not exist" % cabinet_title
        return
      attachment = self.client.UploadAttachment(
          ms, cabinet, title=title, description=description)
      print "Uploaded: ", attachment.GetAlternateLink().href

Есть upload_attachment Метод, который должен работать. Вы также можете проверить образец кода Для сайтов API он использует этот метод.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top