Pergunta

Estou tentando escrever um script que atualize automaticamente alguns anexos em um site criado e gerenciado nos sites do Google. Isso deve ser possível quando o Google lançou o Sites API em setembro e o Python gdata API reivindicações para apoiar sites. No entanto, o método mais próximo que posso encontrar é chamado client.update, o que me permite atualizar os metadados de um anexo, mas não o conteúdo.

Na API Java, a atualização de um anexo é feita criando um novo MediaFileSource e depois ligando entry.setMediaFileSource(source) Seguido por entry.updateMedia(). No entanto, não consigo encontrar nada semelhante na API do Python. Sou burro e apenas perdendo alguma coisa, ou não é possível atualizar um anexo do Google Sites usando a API Python?

Foi útil?

Solução

A API de sites foi atualizada para v1.1; Esta é provavelmente uma nova adição

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

Outras dicas

A documentação aqui Fornece um exemplo sobre como atualizar o conteúdo e os metadados de um anexo (subseção substituindo o conteúdo e os metadados de um anexo)

A única coisa que deixou de fora é obter existing_attachment O que pode ser feito facilmente com algo assim:

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

Ok, a API é estranha e a documentação não é muito clara. Aqui está o que eu descobri. Primeira vez que você faz upload de um anexo, você faz isso através do método de uploadtachment, mas nas tentativas de acompanhamento, você precisa ligar para a atualização. Aqui está o código que faz isso:

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

Há um upload_attachment método, isso deve funcionar. Você também pode querer verificar o Código de amostra Para sites API, ele usa esse método.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top