Как обновить контент вложения с помощью API Python Python API Google Sites?
-
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 он использует этот метод.