Fazer upload dos dados do arquivo

A API Google Drive permite fazer upload de dados de arquivos ao criar ou atualizar um File. Para saber como criar um arquivo somente de metadados, como uma pasta, consulte Criar arquivos somente de metadados.

Há três tipos de uploads que você pode realizar:

  • Upload simples (uploadType=media): use esse tipo de upload para transferir um arquivo de mídia pequeno (5 MB ou menos) sem fornecer metadados. Para realizar um upload simples, consulte Fazer um upload simples.

  • Upload de várias partes (uploadType=multipart): "Use esse tipo de upload para transferir um arquivo pequeno (5 MB ou menos) com os metadados que o descrevem em uma única solicitação. Para fazer um upload de várias partes, consulte Fazer um upload de várias partes.

  • Upload retomável (uploadType=resumable): use esse tipo de upload para arquivos grandes (com mais de 5 MB) e quando houver uma grande chance de interrupção de rede, como ao criar um arquivo em um app para dispositivos móveis. Os uploads retomáveis também são uma boa opção para a maioria dos aplicativos, porque também funcionam com arquivos pequenos com um custo mínimo de uma solicitação HTTP extra por upload. Para fazer um upload retomável, consulte Fazer um upload retomável.

As bibliotecas de cliente da API do Google implementam pelo menos um desses tipos de envios. Consulte a documentação da biblioteca de cliente para mais detalhes sobre como usar cada um dos tipos.

Usar PATCH em vez de PUT

Para relembrar, o verbo HTTP PATCH oferece suporte a uma atualização de recurso de arquivo parcial, enquanto o verbo HTTP PUT oferece suporte à substituição completa de recursos. Observe que PUT pode introduzir alterações interruptivas ao adicionar um novo campo a um recurso existente.

Ao fazer o upload de um recurso de arquivo, siga estas diretrizes:

  • Use o verbo HTTP documentado na referência da API para a solicitação inicial de um upload retomável ou para a única solicitação de um upload simples ou de várias partes.
  • Use PUT para todas as solicitações subsequentes de um upload retomável assim que a solicitação for iniciada. Essas solicitações estão fazendo upload de conteúdo, não importa o método chamado.

Fazer um upload simples

Para fazer um upload simples, use o método files.create com uploadType=media.

Confira a seguir como fazer um upload simples:

HTTP

  1. Crie uma solicitação POST para o URI /upload do método com o parâmetro de consulta uploadType=media:

    POST https://www.googleapis.com/upload/drive/v3/files?uploadType=media

  2. Adicione os dados do arquivo ao corpo da solicitação.

  3. Adicione estes cabeçalhos HTTP:

    • Content-Type. Defina como o tipo de mídia MIME do objeto que está sendo enviado.
    • Content-Length: defina conforme o número de bytes do upload. Se você usar codificação de transferência fragmentada, esse cabeçalho não será necessário.
  4. Envie a solicitação. Se a solicitação for bem-sucedida, o servidor vai retornar o código de status HTTP 200 OK junto com os metadados do arquivo. {HTTP}

Quando você faz um upload simples, metadados básicos são criados e alguns atributos são inferidos do arquivo, como o tipo MIME ou modifiedTime. Você pode usar um upload simples nos casos em que você tem arquivos pequenos e os metadados não são importantes.

Fazer um upload de várias partes

Com uma solicitação de upload de várias partes, você pode fazer upload de metadados e dados na mesma solicitação. Use essa opção se os dados enviados forem pequenos o suficiente para que o upload possa ser refeito inteiramente se a conexão falhar.

Para fazer um upload de várias partes, use o método files.create com uploadType=multipart.

Confira a seguir como fazer um upload de várias partes:

Java

drive/snippets/drive_v3/src/main/java/UploadBasic.java
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.FileContent;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.javanet.NetHttpTransport;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.drive.Drive;
import com.google.api.services.drive.DriveScopes;
import com.google.api.services.drive.model.File;
import com.google.auth.http.HttpCredentialsAdapter;
import com.google.auth.oauth2.GoogleCredentials;
import java.io.IOException;
import java.util.Arrays;

/* Class to demonstrate use of Drive insert file API */
public class UploadBasic {

  /**
   * Upload new file.
   *
   * @return Inserted file metadata if successful, {@code null} otherwise.
   * @throws IOException if service account credentials file not found.
   */
  public static String uploadBasic() throws IOException {
    // Load pre-authorized user credentials from the environment.
    // TODO(developer) - See https://developers.google.com/identity for
    // guides on implementing OAuth2 for your application.
    GoogleCredentials credentials = GoogleCredentials.getApplicationDefault()
        .createScoped(Arrays.asList(DriveScopes.DRIVE_FILE));
    HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(
        credentials);

    // Build a new authorized API client service.
    Drive service = new Drive.Builder(new NetHttpTransport(),
        GsonFactory.getDefaultInstance(),
        requestInitializer)
        .setApplicationName("Drive samples")
        .build();
    // Upload file photo.jpg on drive.
    File fileMetadata = new File();
    fileMetadata.setName("photo.jpg");
    // File's content.
    java.io.File filePath = new java.io.File("files/photo.jpg");
    // Specify media type and file-path for file.
    FileContent mediaContent = new FileContent("image/jpeg", filePath);
    try {
      File file = service.files().create(fileMetadata, mediaContent)
          .setFields("id")
          .execute();
      System.out.println("File ID: " + file.getId());
      return file.getId();
    } catch (GoogleJsonResponseException e) {
      // TODO(developer) - handle error appropriately
      System.err.println("Unable to upload file: " + e.getDetails());
      throw e;
    }
  }
}

Python

drive/snippets/drive-v3/file_snippet/upload_basic.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError
from googleapiclient.http import MediaFileUpload


def upload_basic():
  """Insert new file.
  Returns : Id's of the file uploaded

  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """
  creds, _ = google.auth.default()

  try:
    # create drive api client
    service = build("drive", "v3", credentials=creds)

    file_metadata = {"name": "download.jpeg"}
    media = MediaFileUpload("download.jpeg", mimetype="image/jpeg")
    # pylint: disable=maybe-no-member
    file = (
        service.files()
        .create(body=file_metadata, media_body=media, fields="id")
        .execute()
    )
    print(f'File ID: {file.get("id")}')

  except HttpError as error:
    print(f"An error occurred: {error}")
    file = None

  return file.get("id")


if __name__ == "__main__":
  upload_basic()

Node.js

drive/snippets/drive_v3/file_snippets/upload_basic.js
/**
 * Insert new file.
 * @return{obj} file Id
 * */
async function uploadBasic() {
  const fs = require('fs');
  const {GoogleAuth} = require('google-auth-library');
  const {google} = require('googleapis');

  // Get credentials and build service
  // TODO (developer) - Use appropriate auth mechanism for your app
  const auth = new GoogleAuth({
    scopes: 'https://www.googleapis.com/auth/drive',
  });
  const service = google.drive({version: 'v3', auth});
  const requestBody = {
    name: 'photo.jpg',
    fields: 'id',
  };
  const media = {
    mimeType: 'image/jpeg',
    body: fs.createReadStream('files/photo.jpg'),
  };
  try {
    const file = await service.files.create({
      requestBody,
      media: media,
    });
    console.log('File Id:', file.data.id);
    return file.data.id;
  } catch (err) {
    // TODO(developer) - Handle error
    throw err;
  }
}

PHP

drive/snippets/drive_v3/src/DriveUploadBasic.php
use Google\Client;
use Google\Service\Drive;
# TODO - PHP client currently chokes on fetching start page token
function uploadBasic()
{
    try {
        $client = new Client();
        $client->useApplicationDefaultCredentials();
        $client->addScope(Drive::DRIVE);
        $driveService = new Drive($client);
        $fileMetadata = new Drive\DriveFile(array(
        'name' => 'photo.jpg'));
        $content = file_get_contents('../files/photo.jpg');
        $file = $driveService->files->create($fileMetadata, array(
            'data' => $content,
            'mimeType' => 'image/jpeg',
            'uploadType' => 'multipart',
            'fields' => 'id'));
        printf("File ID: %s\n", $file->id);
        return $file->id;
    } catch(Exception $e) {
        echo "Error Message: ".$e;
    } 

}

.NET

drive/snippets/drive_v3/DriveV3Snippets/UploadBasic.cs
using Google.Apis.Auth.OAuth2;
using Google.Apis.Drive.v3;
using Google.Apis.Services;

namespace DriveV3Snippets
{
    // Class to demonstrate use of Drive insert file API
    public class UploadBasic
    {
        /// <summary>
        /// Upload new file.
        /// </summary>
        /// <param name="filePath">Image path to upload.</param>
        /// <returns>Inserted file metadata if successful, null otherwise.</returns>
        public static string DriveUploadBasic(string filePath)
        {
            try
            {
                /* Load pre-authorized user credentials from the environment.
                 TODO(developer) - See https://developers.google.com/identity for
                 guides on implementing OAuth2 for your application. */
                GoogleCredential credential = GoogleCredential.GetApplicationDefault()
                    .CreateScoped(DriveService.Scope.Drive);

                // Create Drive API service.
                var service = new DriveService(new BaseClientService.Initializer
                {
                    HttpClientInitializer = credential,
                    ApplicationName = "Drive API Snippets"
                });

                // Upload file photo.jpg on drive.
                var fileMetadata = new Google.Apis.Drive.v3.Data.File()
                {
                    Name = "photo.jpg"
                };
                FilesResource.CreateMediaUpload request;
                // Create a new file on drive.
                using (var stream = new FileStream(filePath,
                           FileMode.Open))
                {
                    // Create a new file, with metadata and stream.
                    request = service.Files.Create(
                        fileMetadata, stream, "image/jpeg");
                    request.Fields = "id";
                    request.Upload();
                }

                var file = request.ResponseBody;
                // Prints the uploaded file id.
                Console.WriteLine("File ID: " + file.Id);
                return file.Id;
            }
            catch (Exception e)
            {
                // TODO(developer) - handle error appropriately
                if (e is AggregateException)
                {
                    Console.WriteLine("Credential Not found");
                }
                else if (e is FileNotFoundException)
                {
                    Console.WriteLine("File not found");
                }
                else
                {
                    throw;
                }
            }
            return null;
        }
    }
}

HTTP

  1. Crie uma solicitação POST para o URI /upload do método com o parâmetro de consulta uploadType=multipart:

    POST https://www.googleapis.com/upload/drive/v3/files?uploadType=multipart

  2. Crie o corpo da solicitação. Formate o corpo de acordo com o tipo de conteúdo relacionado a várias partes RFC 2387, que contém duas partes:

    • Metadados. Os metadados precisam vir primeiro e ter um cabeçalho Content-Type definido como application/json; charset=UTF-8. Adicione os metadados do arquivo no formato JSON.
    • Mídia. A mídia precisa vir em segundo lugar e ter um cabeçalho Content-Type de qualquer tipo MIME. Adicione os dados do arquivo à parte de mídia.

    Identifique cada parte com uma string de limite, precedida por dois hifens. Além disso, adicione dois hifens após a string limite final.

  3. Adicione estes cabeçalhos HTTP de nível superior:

    • Content-Type. Defina como multipart/related e inclua a string de limite que você está usando para identificar as diferentes partes da solicitação. Por exemplo: Content-Type: multipart/related; boundary=foo_bar_baz
    • Content-Length. Defina com o número total de bytes no corpo da solicitação.
  4. Envie a solicitação.

Para criar ou atualizar somente a parte de metadados, sem os dados associados, envie uma solicitação POST ou PATCH para o endpoint de recurso padrão: https://www.googleapis.com/drive/v3/files Se a solicitação for bem-sucedida, o servidor retornará o código de status HTTP 200 OK com os metadados do arquivo.

Ao criar arquivos, eles precisam especificar uma extensão no campo name do arquivo. Por exemplo, ao criar um arquivo JPEG de foto, você pode especificar algo como "name": "photo.jpg" nos metadados. As chamadas subsequentes para files.get retornam a propriedade fileExtension somente leitura que contém a extensão especificada originalmente no campo name.

Fazer um upload retomável

Um upload retomável permite retomar uma operação de upload depois que uma falha de comunicação interrompe o fluxo de dados. Como você não precisa reiniciar os uploads de arquivos grandes desde o início, os uploads retomáveis também podem reduzir o uso da largura de banda em caso de falha de rede.

Os uploads retomáveis são úteis quando os tamanhos dos arquivos podem variar muito ou quando há um limite de tempo fixo para solicitações (como tarefas em segundo plano do SO para dispositivos móveis e determinadas solicitações do App Engine). Também é possível usar uploads retomáveis para situações em que você quer mostrar uma barra de progresso de upload.

Um upload retomável consiste em várias etapas de alto nível:

  1. Envie a solicitação inicial e extraia o URI da sessão retomável.
  2. Faça upload dos dados e monitore o estado do upload.
  3. (Opcional) Se houver problemas, retome o upload.

Enviar a solicitação inicial

Para iniciar um upload retomável, use o método files.create com uploadType=resumable.

HTTP

  1. Crie uma solicitação POST para o URI /upload do método com o parâmetro de consulta uploadType=resumable:

    POST https://www.googleapis.com/upload/drive/v3/files?uploadType=resumable

    Se a solicitação de ativação for bem-sucedida, a resposta incluirá um código de status HTTP 200 OK. Além disso, ela inclui um cabeçalho Location que especifica o URI da sessão retomável:

    HTTP/1.1 200 OK
    Location: https://www.googleapis.com/upload/drive/v3/files?uploadType=resumable&upload_id=xa298sd_sdlkj2
    Content-Length: 0
    

    Salve o URI da sessão retomável para fazer upload dos dados do arquivo e consultar o status do upload. Um URI de sessão retomável expira após uma semana.

  2. Se você tiver os metadados do arquivo, adicione-os ao corpo da solicitação no formato JSON. Caso contrário, deixe o corpo em branco.

  3. Adicione estes cabeçalhos HTTP:

    • X-Upload-Content-Type: opcional. Defina como o tipo MIME dos dados de arquivo, que serão transferido nas solicitações subsequentes. Se o tipo MIME dos dados não for especificado nos metadados ou por meio desse cabeçalho, o objeto será exibido como application/octet-stream.
    • X-Upload-Content-Length: opcional. Defina como o número de bytes dos dados do arquivo, que são transferidos em solicitações subsequentes.
    • Content-Type: obrigatório se você tiver os metadados do arquivo. Defina como application/json; charset=UTF-8.
    • Content-Length: obrigatório, a menos que você use a codificação de transferência em partes. Defina conforme o número de bytes no corpo dessa solicitação inicial.
  4. Envie a solicitação. Se a solicitação de início da sessão for bem-sucedida, a resposta incluirá um código de status 200 OK HTTP. Além disso, a resposta inclui um cabeçalho Location que especifica o URI da sessão retomável. Use esse URI para fazer upload dos dados do arquivo e consultar o status do upload. Um URI de sessão retomável expira após uma semana.

  5. Copie e salve o URL da sessão retomável.

  6. Continue para Enviar o conteúdo.

Fazer upload do conteúdo

Há duas formas de fazer o upload de um arquivo com uma sessão retomável:

  • Fazer upload de conteúdo em uma única solicitação: use essa abordagem quando o arquivo puder ser enviado em uma solicitação, se não houver um limite de tempo fixo para nenhuma solicitação ou se você não precisar exibir um indicador de progresso de upload. Essa abordagem é a melhor porque requer menos solicitações e resulta em melhor desempenho.
  • Faça upload do conteúdo em vários fragmentos: use essa abordagem se precisar reduzir a quantidade de dados transferidos em uma única solicitação. Pode ser necessário reduzir os dados transferidos quando houver um limite de tempo fixo para solicitações individuais, como pode acontecer com determinadas classes de solicitações do App Engine. Essa abordagem também é útil quando você precisa fornecer um indicador personalizado para mostrar o progresso do upload.

HTTP: solicitação única

  1. Crie uma solicitação PUT para o URI da sessão retomável.
  2. Adicione os dados do arquivo ao corpo da solicitação.
  3. Adicione um cabeçalho HTTP Content-Length definido como o número de bytes no arquivo.
  4. Envie a solicitação. Se a solicitação de upload for interrompida ou você receber uma resposta 5xx, siga o procedimento em Retomar um upload interrompido.

HTTP: várias solicitações

  1. Crie uma solicitação PUT para o URI da sessão retomável.

  2. Adicione os dados de cada parte ao corpo da solicitação. Crie partes em múltiplos de 256 KB (256 x 1.024 bytes), exceto o fragmento final que conclui o upload. Mantenha o tamanho do bloco o maior possível para que o upload seja eficiente.

  3. Adicione estes cabeçalhos HTTP:

    • Content-Length: defina como o número de bytes na parte atual.
    • Content-Range. Defina para mostrar de quais bytes no arquivo você está fazendo upload. Por exemplo, Content-Range: bytes 0-524287/2000000 mostra que você fez o upload dos primeiros 524.288 bytes (256 x 1.024 x 2) em um arquivo de 2 milhões de bytes.
  4. Envie a solicitação e processe a resposta. Se a solicitação de upload for interrompida ou você receber uma resposta 5xx, siga o procedimento em Retomar um upload interrompido.

  5. Repita as etapas de 1 a 4 para cada parte que permanecer no arquivo. Use o cabeçalho Range na resposta para determinar o início da próxima parte. Não suponha que o servidor recebeu todos os bytes enviados na solicitação anterior.

Quando o upload do arquivo inteiro estiver concluído, você receberá uma resposta 200 OK ou 201 Created, além dos metadados associados ao recurso.

Retomar um upload interrompido

Se uma solicitação de upload for encerrada antes de receber uma resposta ou você receber uma resposta 503 Service Unavailable, será necessário retomar o upload interrompido.

HTTP

  1. Para saber o status do upload, crie uma solicitação PUT vazia para o URI de sessão retomável.

  2. Adicione um cabeçalho Content-Range para indicar que a posição atual no arquivo é desconhecida. Por exemplo, defina Content-Range como */2000000 se o tamanho total do arquivo for de 2.000.000 bytes. Se você não souber o tamanho total do arquivo, defina Content-Range como */*.

  3. Envie a solicitação.

  4. Processe a resposta:

    • Uma resposta 200 OK ou 201 Created indica que o upload foi concluído e não é necessário realizar qualquer outra ação.
    • Uma resposta 308 Resume Incomplete indica que você precisa continuar fazendo o upload do arquivo.
    • Uma resposta 404 Not Found indica que a sessão de upload expirou e o upload precisa ser reiniciado do início.
  5. Se você recebeu uma resposta 308 Resume Incomplete, processe o cabeçalho Range da resposta para determinar quais bytes o servidor recebeu. Se a resposta não tiver um cabeçalho Range, nenhum byte foi recebido. Por exemplo, um cabeçalho Range com valor bytes=0-42 indica que os primeiros 43 bytes do arquivo foram recebidos e que o próximo fragmento a ser enviado seria iniciado com o byte 44.

  6. Agora que você já sabe em que ponto retomar o upload, continue a operação começando pelo próximo byte. Inclua um cabeçalho Content-Range para indicar qual parte do arquivo você envia. Por exemplo, Content-Range: bytes 43-1999999 indica que você envia os bytes 44 a 2.000.000.

Processar erros de upload de mídia

Ao fazer upload de mídia, siga estas práticas recomendadas para lidar com erros:

  • Para erros 5xx, retome ou repita os uploads que falharem devido a interrupções de conexão. Para mais informações sobre como lidar com erros 5xx, consulte Erros 500, 502, 503 e 504.
  • Para erros 403 rate limit, tente fazer o upload novamente. Para mais informações sobre como lidar com erros 403 rate limit, consulte Erro 403: rateLimitExceeded.
  • Para erros 4xx (incluindo 403) durante um upload retomável, reinicie o upload. Esses erros indicam que a sessão de upload expirou e precisa ser reiniciada solicitando um novo URI de sessão. As sessões de upload também expiram após uma semana de inatividade.

Tipos de importação para os Documentos Google

Ao criar um arquivo no Drive, você pode querer convertê-lo em um tipo de arquivo do Google Workspace, como Documentos ou Planilhas Google. Por exemplo, talvez você queira transformar um documento do seu processador de texto favorito em um documento do Google Docs para aproveitar os recursos dele.

Para converter um arquivo em um tipo específico do Google Workspace, especifique o mimeType do Google Workspace ao criar o arquivo.

Confira a seguir como converter um arquivo CSV em uma planilha do Google Workspace:

Java

drive/snippets/drive_v3/src/main/java/UploadWithConversion.java
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.FileContent;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.javanet.NetHttpTransport;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.drive.Drive;
import com.google.api.services.drive.DriveScopes;
import com.google.api.services.drive.model.File;
import com.google.auth.http.HttpCredentialsAdapter;
import com.google.auth.oauth2.GoogleCredentials;
import java.io.IOException;
import java.util.Arrays;

/* Class to demonstrate Drive's upload with conversion use-case. */
public class UploadWithConversion {

  /**
   * Upload file with conversion.
   *
   * @return Inserted file id if successful, {@code null} otherwise.
   * @throws IOException if service account credentials file not found.
   */
  public static String uploadWithConversion() throws IOException {
    // Load pre-authorized user credentials from the environment.
    // TODO(developer) - See https://developers.google.com/identity for
    // guides on implementing OAuth2 for your application.
    GoogleCredentials credentials = GoogleCredentials.getApplicationDefault()
        .createScoped(Arrays.asList(DriveScopes.DRIVE_FILE));
    HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(
        credentials);

    // Build a new authorized API client service.
    Drive service = new Drive.Builder(new NetHttpTransport(),
        GsonFactory.getDefaultInstance(),
        requestInitializer)
        .setApplicationName("Drive samples")
        .build();

    // File's metadata.
    File fileMetadata = new File();
    fileMetadata.setName("My Report");
    fileMetadata.setMimeType("application/vnd.google-apps.spreadsheet");

    java.io.File filePath = new java.io.File("files/report.csv");
    FileContent mediaContent = new FileContent("text/csv", filePath);
    try {
      File file = service.files().create(fileMetadata, mediaContent)
          .setFields("id")
          .execute();
      System.out.println("File ID: " + file.getId());
      return file.getId();
    } catch (GoogleJsonResponseException e) {
      // TODO(developer) - handle error appropriately
      System.err.println("Unable to move file: " + e.getDetails());
      throw e;
    }
  }
}

Python

drive/snippets/drive-v3/file_snippet/upload_with_conversion.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError
from googleapiclient.http import MediaFileUpload


def upload_with_conversion():
  """Upload file with conversion
  Returns: ID of the file uploaded

  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """
  creds, _ = google.auth.default()

  try:
    # create drive api client
    service = build("drive", "v3", credentials=creds)

    file_metadata = {
        "name": "My Report",
        "mimeType": "application/vnd.google-apps.spreadsheet",
    }
    media = MediaFileUpload("report.csv", mimetype="text/csv", resumable=True)
    # pylint: disable=maybe-no-member
    file = (
        service.files()
        .create(body=file_metadata, media_body=media, fields="id")
        .execute()
    )
    print(f'File with ID: "{file.get("id")}" has been uploaded.')

  except HttpError as error:
    print(f"An error occurred: {error}")
    file = None

  return file.get("id")


if __name__ == "__main__":
  upload_with_conversion()

Node.js

drive/snippets/drive_v3/file_snippets/upload_with_conversion.js
/**
 * Upload file with conversion
 * @return{obj} file Id
 * */
async function uploadWithConversion() {
  const fs = require('fs');
  const {GoogleAuth} = require('google-auth-library');
  const {google} = require('googleapis');
  // Get credentials and build service
  // TODO (developer) - Use appropriate auth mechanism for your app
  const auth = new GoogleAuth({
    scopes: 'https://www.googleapis.com/auth/drive',
  });
  const service = google.drive({version: 'v3', auth});
  const fileMetadata = {
    name: 'My Report',
    mimeType: 'application/vnd.google-apps.spreadsheet',
  };
  const media = {
    mimeType: 'text/csv',
    body: fs.createReadStream('files/report.csv'),
  };

  try {
    const file = await service.files.create({
      requestBody: fileMetadata,
      media: media,
      fields: 'id',
    });
    console.log('File Id:', file.data.id);
    return file.data.id;
  } catch (err) {
    // TODO(developer) - Handle error
    throw err;
  }
}

PHP

drive/snippets/drive_v3/src/DriveUploadWithConversion.php
use Google\Client;
use Google\Service\Drive;
function uploadWithConversion()
{
    try {
        $client = new Client();
        $client->useApplicationDefaultCredentials();
        $client->addScope(Drive::DRIVE);
        $driveService = new Drive($client);
        $fileMetadata = new Drive\DriveFile(array(
            'name' => 'My Report',
            'mimeType' => 'application/vnd.google-apps.spreadsheet'));
        $content = file_get_contents('../files/report.csv');
        $file = $driveService->files->create($fileMetadata, array(
            'data' => $content,
            'mimeType' => 'text/csv',
            'uploadType' => 'multipart',
            'fields' => 'id'));
        printf("File ID: %s\n", $file->id);
        return $file->id;
    } catch(Exception $e) {
        echo "Error Message: ".$e;
    }

}

.NET

drive/snippets/drive_v3/DriveV3Snippets/UploadWithConversion.cs
using Google.Apis.Auth.OAuth2;
using Google.Apis.Drive.v3;
using Google.Apis.Services;

namespace DriveV3Snippets
{
    // Class to demonstrate Drive's upload with conversion use-case.
    public class UploadWithConversion
    {
        /// <summary>
        /// Upload file with conversion.
        /// </summary>
        /// <param name="filePath">Id of the spreadsheet file.</param>
        /// <returns>Inserted file id if successful, null otherwise.</returns>
        public static string DriveUploadWithConversion(string filePath)
        {
            try
            {
                /* Load pre-authorized user credentials from the environment.
                 TODO(developer) - See https://developers.google.com/identity for
                 guides on implementing OAuth2 for your application. */
                GoogleCredential credential = GoogleCredential.GetApplicationDefault()
                    .CreateScoped(DriveService.Scope.Drive);

                // Create Drive API service.
                var service = new DriveService(new BaseClientService.Initializer
                {
                    HttpClientInitializer = credential,
                    ApplicationName = "Drive API Snippets"
                });

                // Upload file My Report on drive.
                var fileMetadata = new Google.Apis.Drive.v3.Data.File()
                {
                    Name = "My Report",
                    MimeType = "application/vnd.google-apps.spreadsheet"
                };
                FilesResource.CreateMediaUpload request;
                // Create a new drive.
                using (var stream = new FileStream(filePath,
                           FileMode.Open))
                {
                    // Create a new file, with metadata and stream.
                    request = service.Files.Create(
                        fileMetadata, stream, "text/csv");
                    request.Fields = "id";
                    request.Upload();
                }

                var file = request.ResponseBody;
                // Prints the uploaded file id.
                Console.WriteLine("File ID: " + file.Id);
                return file.Id;
            }
            catch (Exception e)
            {
                // TODO(developer) - handle error appropriately
                if (e is AggregateException)
                {
                    Console.WriteLine("Credential Not found");
                }
                else if (e is FileNotFoundException)
                {
                    Console.WriteLine("File not found");
                }
                else
                {
                    throw;
                }
            }
            return null;
        }
    }
}

Para saber se uma conversão está disponível, verifique a matriz importFormats do recurso about antes de criar o arquivo. As conversões compatíveis são disponibilizadas dinamicamente nessa matriz. Alguns formatos de importação comuns são:

DePara
Microsoft Word, OpenDocument Text, HTML, RTF, texto simplesDocumentos Google
Microsoft Excel, planilha do OpenDocument, CSV, TSV, texto simplesPlanilhas Google
Microsoft PowerPoint, apresentação do OpenDocumentApresentações Google
JPEG, PNG, GIF, BMP, PDFDocumentos Google (incorpora a imagem a um documento)
Texto simples (tipo MIME especial), JSONGoogle Apps Script

Quando você faz upload e converte mídia durante uma solicitação update para um arquivo do Documentos, Planilhas ou Apresentações, o conteúdo completo do documento é substituído.

Quando você converte uma imagem em um documento, o Drive usa o reconhecimento óptico de caracteres (OCR) para converter a imagem em texto. É possível melhorar a qualidade do algoritmo de OCR especificando o código de idioma BCP 47 aplicável no parâmetro ocrLanguage. O texto extraído aparece no documento junto com a imagem incorporada.

Usar um ID pré-gerado para fazer upload de arquivos

A API Drive permite recuperar uma lista de IDs de arquivos pré-gerados que são usados para fazer upload e criar recursos. As solicitações de upload e criação de arquivos podem usar esses IDs pré-gerados. Defina o campo id nos metadados do arquivo.

Para criar IDs pré-gerados, chame files.generateIds com o número de IDs a serem criados.

Você pode tentar novamente os uploads com IDs pré-gerados se houver um erro indeterminado do servidor ou um tempo limite. Se o arquivo foi criado, as tentativas posteriores vão retornar um erro HTTP 409 e não vão criar arquivos duplicados.

Definir texto indexável para tipos de arquivo desconhecidos

Os usuários podem usar a interface do Drive para encontrar o conteúdo do documento. Você também pode usar files.list e o campo fullText para pesquisar conteúdo do seu app. Para mais informações, consulte Pesquisar arquivos e pastas.

O Drive indexa automaticamente documentos para pesquisa quando reconhece o tipo de arquivo, incluindo documentos de texto, PDFs, imagens com texto e outros tipos comuns. Se o app salvar outros tipos de arquivos (como desenhos, vídeos e atalhos), você pode melhorar a capacidade de descoberta fornecendo texto indexável no campo contentHints.indexableText do arquivo.

Para mais informações sobre texto indexável, consulte Gerenciar metadados de arquivo.