如何通过python API将json / pickle文件转储并读入Google Drive?

我从这里下载了开始代码http://goo.gl/Tcxkod并按照说明安装了XP001中的sample.py:

alvas@ubi:~/git/UniversalCorpus/drive-cmd-line-sample$python sample.py
Success! Now add code here.

但是如何将pickle / json文件转储到驱动器上然后检索它以从python中读取?

我点击了dev文档,除了repr和源代码本身之外没有任何线索:https://developers.google.com/resources/api-libraries/documentation/drive/v2/python/latest/drive_v2.files.html#get

最佳答案
使用PyDrive

我测试了PyDrive,我觉得它非常直截了当.这是我做的:

from pydrive.auth import GoogleAuth
from pydrive.drive import GoogleDrive

gauth = GoogleAuth()
gauth.LocalWebserverAuth()

drive = GoogleDrive(gauth)

# Upload a json file (will be identical for a pickle file)
json_file = drive.CreateFile()
json_file.SetContentFile('wopwop.json')
json_file.Upload() # Files.insert()
print json_file['title'],json_file['id']

# Download the same json file
same_json_file = drive.CreateFile({'id': json_file['id']})
same_json_file.GetContentFile('test.json')  # Save Drive file as a local file

这段代码有两个“问题”:

>如果您在每次使用时都同意,它会在浏览器中询问您.阅读this page让他记住你的答案.
>如您所见,您需要记住文件的唯一标识符(id).您可以将它们放在数据库或本地json文件中.您也可以使用PyDrive到list all files matching a query,从而为您提供ID.

没有PyDrive

如果您对使用PyDrive不感兴趣,我强烈建议您阅读其代码.如果我必须这样做,我会在pydrive.files中放置3个断点(或打印):

>在_FilesInsert上的self.auth.service.files()行.insert(** param).execute()
>在_FilesUpdate上行self.auth.service.files().update(** param).execute()
>在_DownloadFromUrl上的self.auth.service._http.request(url)行和构造函数中查看他如何获取url(它在self.Metadata中)

您已经使用在sample.py中下载的代码获得服务,因此您只需要知道param字典中的内容即可了解正在进行的操作.

但是,你应该使用PyDrive;)

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...