किसी फ़ाइल पर लेबल फ़ील्ड सेट करना

इस पेज पर, Google Drive की किसी एक फ़ाइल पर लेबल Field सेट करने का तरीका बताया गया है.

किसी फ़ाइल पर लेबल सेट करके, उसमें मेटाडेटा जोड़ने के लिए, files.modifyLabels तरीके का इस्तेमाल करें. अनुरोध के मुख्य हिस्से में, किसी फ़ाइल पर सेट किए गए लेबल में बदलाव करने के लिए, ModifyLabelsRequest का एक इंस्टेंस शामिल होता है. अनुरोध में कई बदलाव शामिल हो सकते हैं, जो एक साथ लागू होते हैं. इसका मतलब है कि अगर कोई बदलाव मान्य नहीं है, तो पूरा अपडेट पूरा नहीं होगा. साथ ही, (संभावित तौर पर एक-दूसरे पर निर्भर) कोई भी बदलाव लागू नहीं होगा.

ModifyLabelsRequest में LabelModification का एक इंस्टेंस शामिल होता है. यह किसी फ़ाइल पर मौजूद लेबल में किया गया बदलाव होता है. इसमें का FieldModification एक इंस्टेंस भी शामिल हो सकता है. यह किसी लेबल के फ़ील्ड में किया गया बदलाव होता है.

अनुरोध के सही तरीके से काम करने पर, जवाब के मुख्य हिस्से में वे लेबल शामिल होते हैं जिन्हें जोड़ा गया है या अपडेट किया गया है. ये modifiedLabels ऑब्जेक्ट में मौजूद होते हैं, जिसका टाइप Label है.

उदाहरण

नीचे दिए गए कोड के नमूने में, किसी फ़ाइल पर मौजूद इस Field के लिए वैल्यू सेट करने के लिए, टेक्स्ट फ़ील्ड के fieldId का इस्तेमाल करने का तरीका बताया गया है. जब किसी फ़ाइल पर Field लेबल पहली बार सेट किया जाता है, तो वह लेबल उस फ़ाइल पर लागू हो जाता है. इसके बाद, किसी एक फ़ील्ड को अनसेट किया जा सकता है या लेबल से जुड़े सभी फ़ील्ड हटाए जा सकते हैं. ज़्यादा जानकारी के लिए, किसी फ़ाइल पर मौजूद लेबल का फ़ील्ड अनसेट करना और किसी फ़ाइल से लेबल हटाना लेख पढ़ें.

Java

LabelFieldModification fieldModification =
new LabelFieldModification().setFieldId("FIELD_ID").setSetTextValues(ImmutableList.of("VALUE"));

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','setTextValues':['VALUE']}
label_modification = {'labelId':'LABEL_ID', 'fieldModifications':[field_modification]}

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

Node.js

/**
* Set a label with a text field on a Drive file
* @return{obj} updated label data
**/
async function setLabelTextField() {
  // 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',
    'setTextValues': ['VALUE'],
  };
  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;
  }
}

इनकी जगह ये डालें:

  • FIELD_ID: बदलाव करने के लिए, फ़ील्ड का fieldId. fieldId ढूंढने के लिए, Google Drive Labels API का इस्तेमाल करके लेबल वापस पाएं.
  • VALUE: इस फ़ील्ड के लिए नई value.
  • LABEL_ID: बदलाव करने के लिए, लेबल का labelId.
  • FILE_ID: वह fileId जिसके लेबल में बदलाव किया गया है.

नोट

  • बिना फ़ील्ड वाला लेबल सेट करने के लिए, labelModifications लागू करें. इसमें कोई fieldModifications मौजूद नहीं होना चाहिए.
  • चुने गए फ़ील्ड के विकल्पों के लिए वैल्यू सेट करने के लिए, उस वैल्यू का Choice आईडी इस्तेमाल करें जिसे Drive Labels API में लेबल स्कीमा फ़ेच करके पाया जा सकता है.
  • सिर्फ़ ऐसे Field के लिए कई वैल्यू सेट की जा सकती हैं जो वैल्यू की सूचियों के साथ काम करता है. ऐसा न करने पर, आपको 400: Bad Request गड़बड़ी का जवाब मिलेगा.
  • चुने गए Field के लिए, सही वैल्यू टाइप (जैसे, integer, text, user वगैरह) सेट करें. ऐसा न करने पर, आपको 400: Bad Request गड़बड़ी का जवाब मिलेगा. Drive Labels API का इस्तेमाल करके, फ़ील्ड का डेटा टाइप वापस पाया जा सकता है.