Annullare l'impostazione di un campo etichetta in un file

Questa pagina descrive come annullare l'impostazione di un'etichetta Field su un singolo file di Google Drive.

Per rimuovere i metadati da un file disattivando un'etichetta, utilizza il metodo files.modifyLabels. Il corpo della richiesta contiene un'istanza di ModifyLabelsRequest per modificare l'insieme di etichette in un file. La richiesta potrebbe contenere diverse modifiche applicate in modo atomico. In altre parole, se le modifiche non sono valide, l'intero aggiornamento non va a buon fine e nessuna delle modifiche (potenzialmente dipendenti) viene applicata.

ModifyLabelsRequest contiene un'istanza di LabelModification che è una modifica a un'etichetta in un file. Potrebbe anche contenere un'istanza di FieldModification, che è una modifica al campo di un'etichetta. Per annullare l'impostazione dei valori per il campo, imposta FieldModification.unsetValues su True.

In caso di esito positivo, il corpo della risposta contiene le etichette aggiunte o aggiornate dalla richiesta. Esistono all'interno di un oggetto modifiedLabels di tipo Label.

Esempio

Il seguente esempio di codice mostra come utilizzare fieldId e labelId per annullare l'impostazione del valore del campo nell'elemento fileId associato. Ad esempio, se un'etichetta contiene sia campi di testo che campi utente, la disattivazione del campo di testo lo rimuove dall'etichetta, ma lascia invariato il campo utente. La rimozione di un'etichetta, invece, elimina entrambi il testo e i campi utente associati all'etichetta. Per saperne di più, vedi Rimuovere un'etichetta da un file.

Java

LabelFieldModification fieldModification =
  new LabelFieldModification().setFieldId("FIELD_ID").setUnsetValues(true);

ModifyLabelsRequest modifyLabelsRequest =
  new ModifyLabelsRequest()
      .setLabelModifications(
          ImmutableList.of(
              new LabelModification()
                .setLabelId("LABEL_ID")
                .setFieldModifications(ImmutableList.of(fieldModification))));

ModifyLabelsResponse modifyLabelsResponse = driveService.files().modifyLabels("FILE_ID", modifyLabelsRequest).execute();

Python

field_modification = {'fieldId':'FIELD_ID','unsetValues':True}
label_modification = {'labelId':'LABEL_ID', 'fieldModifications':[field_modification]}

modified_labels = drive_service.files().modifyLabels(fileId="FILE_ID", body = {'labelModifications' : [label_modification]}).execute();

Node.js

/**
* Unset a label with a field on a Drive file
* @return{obj} updated label data
**/
async function unsetLabelField() {
  // Get credentials and build service
  // TODO (developer) - Use appropriate auth mechanism for your app

  const {GoogleAuth} = require('google-auth-library');
  const {google} = require('googleapis');

  const auth = new GoogleAuth({scopes: 'https://www.googleapis.com/auth/drive'});
  const service = google.drive({version: 'v3', auth});
  const fieldModification = {
    'fieldId': 'FIELD_ID',
    'unsetValues': True,
  };
  const labelModification = {
    'labelId': 'LABEL_ID',
    'fieldModifications': [fieldModification],
  };
  const labelModificationRequest = {
    'labelModifications': [labelModification],
  };
  try {
    const updateResponse = await service.files.modifyLabels({
      fileId: 'FILE_ID',
      resource: labelModificationRequest,
    });
    return updateResponse;
  } catch (err) {
    // TODO (developer) - Handle error
    throw err;
  }
}

Sostituisci quanto segue:

  • FIELD_ID: il fieldId del campo da modificare. Per trovare fieldId, recupera l'etichetta utilizzando l'API Google Drive Labels.
  • LABEL_ID: il labelId dell'etichetta da modificare.
  • FILE_ID: il fileId del file per cui vengono modificate le etichette.