После успешного завершения операции и извлечения имени ресурса из ответа о завершенной операции вы готовы загрузить zip-файл, содержащий сгенерированные файлы SDF, с помощью метода media.download
.
Вот пример использования клиентской библиотеки для загрузки полученного файла:
Ява
// Extract download file resource name to use in download request String downloadResourceName = operationResponse.getResponse() .get("resourceName").toString(); // Configure the Media.download request Media.Download downloadRequest = service .media() .download(downloadResourceName); // Create output stream for downloaded file FileOutputStream outStream = new FileOutputStream(output-file); // Download file downloadRequest.executeMediaAndDownloadTo(outStream); System.out.printf("File downloaded to %s\n", outputFile);
Питон
# Extract download file resource name to use in download request resourceName = operation["response"]["resourceName"] # Configure the Media.download request downloadRequest = service.media().download_media(resourceName=resourceName) # Create output stream for downloaded file outStream = io.FileIO(output-file, mode='wb') # Make downloader object downloader = googleHttp.MediaIoBaseDownload(outStream, downloadRequest) # Download media file in chunks until finished download_finished = False while download_finished is False: _, download_finished = downloader.next_chunk() print("File downloaded to %s" % output-file)
PHP
// Get client and set defer so it doesn't immediately return. $client = $this->service->getClient(); $client->setDefer(true); // Build media download request. $request = $this->service->media->download( $operation->getResponse()['resourceName'], array('alt' => 'media') ); // Call the API, getting the generated SDF. $response = $client->execute($request); $responseBody = $response->getBody(); // Writes the downloaded file. If the file already exists, it is // overwritten. file_put_contents(output-file, $responseBody); $client->setDefer(false); printf('File saved to: %s\n', output-file);
Как только ваш файл будет загружен и распакован, вам станут доступны сгенерированные файлы структурированных данных. Сгенерированные файлы будут иметь общие имена, идентифицирующие тип файла SDF (пример: SDF-LineItems.csv
).
Пропущенные файлы
Если данные для запрошенного ресурса не могут быть включены в соответствующий файл структурированных данных, загруженный zip-файл может содержать «пропущенный» файл (пример: SDF-LineItems-Skipped.csv
). Этот файл будет иметь структуру из двух столбцов: первый будет содержать идентификаторы ресурсов, которые не удалось включить, а второй — причину их исключения.
Ресурсы могут быть пропущены по многим причинам, в том числе из-за того, что они находятся в неподдерживаемом состоянии или имеют неподдерживаемый тип. Избегайте пропуска ресурсов, используя самую последнюю версию SDF.