我正在尝试将本地CSV文件上传到Google云端硬盘并将其显示为Google电子表格。但是,当我转到我的Google云端硬盘并点击指向我文件的链接时,我只能下载它,而不是将其视为电子表格。我尝试过使用?convert=true
,但文件没有转换。我也尝试使用application/vnd.google-apps.spreadsheet
作为mime类型,但注意到更改或我收到400 Bad request
响应。
当我右键单击该文件时,我可以选择使用Google Spreadsheets打开,然后正确显示该文件。我目前在Google的文档中找不到任何相关内容,谷歌上的搜索也没有多大帮助。
到目前为止我所做的是创建一个新的空 Google电子表格,并尝试用我的CSV文件填充它,但这给了我一个500 Internal Error
。
$file = new Google_DriveFile();
$file->setTitle('Exported data from ' . $this->event->title);
$file->setDescription('Exported data from ' . $this->event->title);
$file->setMimeType( 'text/csv' );
try {
$createdFile = $this->drive->files->insert($file, array(
'data' => $data,
'mimeType' => 'application/vnd.google-apps.spreadsheet'
), array('convert'=>true));
// Uncomment the following line to print the File ID
// print 'File ID: %s' % $createdFile->getId();
$additionalParams = array(
'newRevision' => false,
'data' => $data,
'convert'=>true //no change if this is true or false
);
$newFile = $this->drive->files->get( $createdFile->getId() );
$newFile->setMimeType('text/csv');
$updated = $this->drive->files->update($createdFile->getId(), $newFile, $additionalParams);
preint_r($updated);
} catch (Exception $e) {
print "An error occurred: " . $e->getMessage();
}
我查看了Google云端硬盘的API,但没有找到任何有用的内容。我想知道我是否应该使用Google Spreadsheets API或Google Drive API才能单独使用?
非常感谢, 瓦尔德马
答案 0 :(得分:4)
尝试以下方法。它来自Google文档中的File:insert引用,但我添加了convert参数:
/**
* Insert new file.
*
* @param Google_DriveService $service Drive API service instance.
* @param string $title Title of the file to insert, including the extension.
* @param string $description Description of the file to insert.
* @param string $parentId Parent folder's ID.
* @param string $mimeType MIME type of the file to insert.
* @param string $filename Filename of the file to insert.
* @return Google_DriveFile The file that was inserted. NULL is returned if an API error occurred.
*/
function insertFile($service, $title, $description, $parentId, $mimeType, $filename) {
$file = new Google_DriveFile();
$file->setTitle($title);
$file->setDescription($description);
$file->setMimeType($mimeType);
// Set the parent folder.
if ($parentId != null) {
$parent = new ParentReference();
$parent->setId($parentId);
$file->setParents(array($parent));
}
try {
$data = file_get_contents($filename);
$createdFile = $service->files->insert($file, array(
'data' => $data,
'mimeType' => $mimeType,
'convert' => true,
));
// Uncomment the following line to print the File ID
// print 'File ID: %s' % $createdFile->getId();
return $createdFile;
} catch (Exception $e) {
print "An error occurred: " . $e->getMessage();
}
}
答案 1 :(得分:2)
我尝试上面的代码它不适合我 它会在登录后停止
只是使用 $文件 - > setMimeType('应用/ vnd.google-apps.spreadsheet);
$createdFile = $service->files->insert($file, array(
'data' => $data,
'mimeType' => 'text/csv',
'convert' => true,
));
它对我有用
答案 2 :(得分:1)
我必须添加其他参数才能使其正常工作。 'uploadType'=> '多部分'
$createdFile = $service->files->insert($file,array(
'data' => $data,
'mimeType' => 'text/csv',
'convert' => true,
'uploadType' => 'multipart',
));
现在它正在运作。