Membatalkan penetapan kolom label pada file

Halaman ini menjelaskan cara menghapus setelan label Field pada satu file Google Drive.

Untuk menghapus metadata dari file dengan menghapus setelan label file, gunakan metode files.modifyLabels. Isi permintaan berisi instance ModifyLabelsRequest untuk mengubah kumpulan label pada file. Permintaan dapat berisi beberapa modifikasi yang diterapkan secara atomik. Artinya, jika ada modifikasi yang tidak valid, seluruh update akan gagal dan tidak ada perubahan (yang berpotensi bergantung) yang diterapkan.

ModifyLabelsRequest berisi instance LabelModification yang merupakan modifikasi pada label di file. Kolom ini juga dapat berisi instance dari FieldModification yang merupakan modifikasi pada kolom label. Untuk menghapus nilai kolom, tetapkan FieldModification.unsetValues ke True.

Jika berhasil, isi respons akan berisi label yang ditambahkan atau diperbarui oleh permintaan. Objek ini ada dalam objek modifiedLabels berjenis Label.

Contoh

Contoh kode berikut menunjukkan cara menggunakan fieldId dan labelId untuk membatalkan setel nilai kolom pada fileId terkait. Misalnya, jika label berisi kolom teks dan kolom pengguna, menghapus setelan kolom teks akan menghapusnya dari label tetapi tidak mengubah kolom pengguna. Sedangkan menghapus label akan menghapus kedua kolom teks dan pengguna yang terkait dengan label. Untuk mengetahui informasi selengkapnya, lihat Menghapus label dari 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;
  }
}

Ganti kode berikut:

  • FIELD_ID: fieldId kolom yang akan diubah. Untuk menemukan fieldId, ambil label menggunakan Google Drive Labels API.
  • LABEL_ID: labelId label yang akan diubah.
  • FILE_ID: fileId file yang labelnya diubah.