Загрузите SDF-файл

После успешного завершения операции и извлечения имени ресурса из ответа о завершенной операции вы готовы загрузить 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.