AdsApp का इस्तेमाल करने वाले परफ़ॉर्मेंस मैक्स कैंपेन

Google Ads स्क्रिप्ट की मदद से, परफ़ॉर्मेंस मैक्स कैंपेन को कुछ हद तक मैनेज किया जा सकता है. परफ़ॉर्मेंस मैक्स कैंपेन को वापस लाने, ऐसेट ग्रुप को मैनेज करने, और रिपोर्ट चलाने के लिए स्क्रिप्ट का इस्तेमाल किया जा सकता है. हालांकि, परफ़ॉर्मेंस मैक्स कैंपेन बनाने के लिए स्क्रिप्ट का इस्तेमाल नहीं किया जा सकता. ज़्यादा ऐडवांस ऑपरेशन करने के लिए, इस गाइड का बाकी हिस्सा देखें. इसमें, mutate का इस्तेमाल करके, ज़्यादा सामान्य तरीके के बारे में बताया गया है.

परफ़ॉर्मेंस मैक्स कैंपेन को वापस लाना

परफ़ॉर्मेंस मैक्स कैंपेन, AdsApp ऑब्जेक्ट के performanceMaxCampaigns कलेक्शन के ज़रिए उपलब्ध होते हैं. इन्हें पहले की तरह वापस पाया जा सकता है:

const campaignName = "My Performance Max campaign";

const campaignIterator = AdsApp.performanceMaxCampaigns()
    .withCondition(`campaign.name = "${campaignName}"`)
    .get();

for (const campaign of campaignIterator) {
  ...
}

अन्य कैंपेन टाइप के मुकाबले, बेहतरीन परफ़ॉर्मेंस में मदद करने वाले कैंपेन में ऐसे विज्ञापन ग्रुप या विज्ञापन ऑब्जेक्ट नहीं होते जिन्हें देखा जा सकता है. अन्य कैंपेन के लिए, इन कॉन्सेप्ट से जुड़ी हर चीज़ को आपके लिए अपने-आप मैनेज किया जाता है. यह, आपके सेट किए गए एसेट ग्रुप के आधार पर होता है.

ऐसेट और ऐसेट ग्रुप

परफ़ॉर्मेंस मैक्स कैंपेन के विज्ञापन, वीडियो, इमेज, हेडलाइन, और जानकारी जैसी ऐसेट के आधार पर चलते हैं. ये ऐसेट, आपने खुद दी हैं या ये अपने-आप जनरेट हुई हैं. किस तरह की ऐसेट की ज़रूरत होती है, इसकी पूरी जानकारी के लिए Google Ads API के परफ़ॉर्मेंस मैक्स कैंपेन की ऐसेट से जुड़ी गाइड देखें.

परफ़ॉर्मेंस मैक्स कैंपेन की ऐसेट को एक ऐसेट ग्रुप में बंडल किया जाता है. साथ ही, हर परफ़ॉर्मेंस मैक्स कैंपेन में कम से कम एक ऐसेट ग्रुप होना चाहिए. इन ऐसेट ग्रुप को सीधे तौर पर स्क्रिप्ट में नहीं बनाया जा सकता. हालांकि, किसी मौजूदा ऐसेट ग्रुप में ऐसेट जोड़ी और हटाई जा सकती हैं.

ऐसेट ग्रुप में ऐसेट जोड़ना

सबसे पहले, ऐसेट बनाएं:

const imageUrl = "http://www.example.com/example.png";
const imageBlob = UrlFetchApp.fetch(imageUrl).getBlob();
const assetOperation = AdsApp.adAssets().newImageAssetBuilder()
   .withName("new asset name")
   .withData(imageBlob)
   .build();
const imageAsset = assetOperation.getResult();

इसके बाद, अपनी बनाई गई ऐसेट का इस्तेमाल करके, उसे किसी मौजूदा ऐसेट ग्रुप में जोड़ें:

// First, fetch the Performance Max campaign we want to operate on.
const campaignIterator = AdsApp.performanceMaxCampaigns()
   .withCondition(`campaign.name = '${campaignName}'`)
   .get();
let campaign;
if (campaignIterator.hasNext()) {
   campaign = campaignIterator.next();
} else {
   throw `No campaign found with name ${campaignName}.`
}

// Then, get that campaign's asset groups.
const assetGroupIterator = campaign.assetGroups().get();

// The campaign must have at least one asset group, so we can just assume so here.
const assetGroup = assetGroupIterator.next();

// Add the asset from the previous step.
assetGroup.addAsset(imageAsset, 'MARKETING_IMAGE');

ध्यान दें कि आखिरी चरण में, ऐसेट का टाइप कैसे बताना चाहिए. Google Ads API के दस्तावेज़ में, एसेट टाइप की पूरी सूची देखी जा सकती है

किसी मौजूदा ऐसेट का इस्तेमाल करने के लिए, पहले ऐसेट सिलेक्टर बनाएं:

const assetSelector = AdsApp.adAssets().assets();

इसके बाद, withCondition फ़िल्टर का इस्तेमाल करके, उन एसेट को चुनें जिन पर आपको काम करना है. फ़िल्टर के विकल्पों की पूरी सूची देखने के लिए, AssetSelector रेफ़रंस दस्तावेज़ देखें.

आखिर में, आइटरेटर फ़ेच करें और अन्य इकाइयों की तरह ही दोहराएं:

const assetIterator = assetSelector.get();

for (const asset of assetIterator) {
   ...
}

टेक्स्ट ऐसेट

टेक्स्ट ऐसेट, कुछ अलग तरह से काम करती हैं. इनके लिए, आपको पहले से ऐसेट बनाने की ज़रूरत नहीं होती. आपको एसेट के बजाय सिर्फ़ टेक्स्ट की जानकारी देनी होगी. इसके बाद, सिस्टम आपके लिए एसेट अपने-आप बना देगा. अगर टेक्स्ट, किसी मौजूदा टेक्स्ट ऐसेट का एग्ज़ैक्ट डुप्लीकेट है, तो मौजूदा ऐसेट का फिर से इस्तेमाल किया जाएगा.

उदाहरण के लिए, हेडलाइन ऐसेट बनाने का तरीका यहां बताया गया है:

assetGroup.addAsset('asset text here', 'HEADLINE');

ऐसेट ग्रुप से ऐसेट हटाना

किसी ऐसेट ग्रुप से किसी ऐसेट को भी हटाया जा सकता है. हालांकि, ध्यान रखें कि कैंपेन मान्य हो, इसके लिए आपके पास कुछ खास तरह की ऐसेट की तय संख्या होनी चाहिए.

पिछले उदाहरण में जोड़ी गई ऐसेट को हटाने का तरीका यहां बताया गया है:

assetGroup.removeAsset(imageAsset, 'MARKETING_IMAGE');

search फ़ंक्शन की मदद से, किसी ऐसेट ग्रुप में मौजूद ऐसेट की सूची भी देखी जा सकती है:

// The resource name is a unique identifier for this asset group.
const assetGroupName = assetGroup.getResourceName();
results = AdsApp.search(
   `SELECT asset.resource_name, asset_group_asset.field_type
    FROM asset_group_asset
    WHERE asset_group.resource_name = '${assetGroupName}'`
);

यह एसेट के संसाधन के नाम को उसके यूनीक आइडेंटिफ़ायर के तौर पर चुनता है. नतीजों को बेहतर बनाने के लिए, asset.type या asset.text_asset.text जैसे अन्य फ़ील्ड भी चुने जा सकते हैं. अपनी क्वेरी बनाने के लिए, इस रिपोर्ट टाइप के लिए क्वेरी बिल्डर का इस्तेमाल करें.

टारगेट ऐसेट मिलने के बाद, ऐसेट ग्रुप से ऐसेट को हटाने के लिए, ऐसेट ग्रुप पर remove को कॉल करें:

// Let's assume at least one asset is returned. We'll just remove the first
// asset, whatever it is. In your code, customize this to choose the right asset.
const row_info = results.next().asset;
assetGroup.remove(row_info.asset.resource_name, row_info.asset_group_asset.field_type);