Feldmasken

In der Google Ads API werden Aktualisierungen mithilfe einer Feldmaske vorgenommen. Die Feldmaske listet alle Felder, die Sie mit der Aktualisierung ändern möchten, sowie alle angegebenen Felder die nicht in der Feldmaske enthalten sind, werden ignoriert, auch wenn sie an den Server gesendet werden.

Dienstprogramm „FieldMasks“

Die empfohlene Methode zum Generieren von Feldmasken ist die Verwendung unserer integrierten Feldmaske Dienstprogramm (FieldMasks), mit dem Sie Feldmasken aus einem geänderten Objekt generieren können, von Grund auf neu erstellen.

Hier ein Beispiel für die Aktualisierung einer Kampagne:

my $campaign = Google::Ads::GoogleAds::V17::Resources::Campaign->new({
    resourceName =>
      Google::Ads::GoogleAds::V17::Utils::ResourceNames::campaign(
        $customer_id, $campaign_id
      ),
    status => PAUSED,
    networkSettings =>
      Google::Ads::GoogleAds::V17::Resources::NetworkSettings->new({
        targetSearchNetwork => "false"
      })
    });

my $campaign_operation =
  Google::Ads::GoogleAds::V17::Services::CampaignService::CampaignOperation->new({
    update     => $campaign,
    updateMask => all_set_fields_of($campaign)
  });

In diesem Beispiel wird zuerst ein Campaign-Objekt erstellt, indem dessen Ressourcenname festgelegt wird mit dem Dienstprogramm ResourceNames, damit die API weiß, welche Kampagne aktualisiert wird.

In diesem Beispiel wird das FieldMasks::all_set_fields_of() für die Kampagne, um automatisch eine Feldmaske zu erstellen, die alle festlegen. Anschließend können Sie die zurückgegebene Maske direkt an den Aktualisierungsaufruf übergeben.

FieldMasks::all_set_fields_of() ist eine bequeme Methode für FieldMasks::field_mask() Es vergleicht das übergebene Objekt mit einem leeren Objekt derselben Klasse. In der Code oben eingeben, können Sie auch

field_mask(Google::Ads::GoogleAds::V17::Resources::Campaign->new({}), $campaign)

statt all_set_fields_of($campaign).

Maske manuell erstellen

Um eine neue Feldmaske zu erstellen, müssen Sie zuerst eine Google::Ads::GoogleAds::Common::FieldMask und erstellen Sie dann einen Array-Verweis, der mit den Namen aller Felder gefüllt ist. die Sie ändern möchten. Weisen Sie schließlich den Arrayverweis der paths.

my $field_mask = Google::Ads::GoogleAds::Common::FieldMask->new({
    paths => ["status", "name"]
  });

Objektfelder und ihre Unterfelder aktualisieren

Objektfelder können Unterfelder enthalten (z. B. MaximizeConversions mit drei: target_cpa_micros, cpc_bid_ceiling_micros und cpc_bid_floor_micros); oder Sie dürfen auch keine haben (z. B. ManualCpm).

Objektfelder ohne definierte Unterfelder

Ein Objektfeld in Perl entspricht der protobuf-MESSAGE im Client auf gRPC ausgeführte Bibliotheken. Beim Aktualisieren eines nicht definierten Objektfelds mit beliebigen Unterfeldern hinzufügen, verwenden Sie das Dienstprogramm "FieldMasks", um eine Feldmaske wie beschrieben.

Objektfelder mit definierten Unterfeldern

Beim Aktualisieren eines Objektfelds, das mit Unterfeldern ohne explizit oder eines der untergeordneten Felder der Nachricht festgelegt haben, müssen Sie jedes der mutable-Objekt-Unterfelder in FieldMask, ähnlich wie im obigen Beispiel. mit der eine komplett neue Feldmaske erstellt wird.

Ein gängiges Beispiel ist die Aktualisierung der Gebotsstrategie einer Kampagne, ohne der Felder der neuen Gebotsstrategie. Das folgende Beispiel zeigt, wie Sie Kampagne aktualisieren, um Gebotsstrategie MaximizeConversions ohne Unterfelder der Gebotsstrategie festzulegen.

In diesem Fall wird mithilfe der Methoden all_set_fields_of() und field_mask() der Das Dienstprogramm FieldMasks erreicht nicht das vorgesehene Ziel.

Im folgenden Beispiel wird eine Feldmaske generiert, die Folgendes enthält: maximize_conversions Die Google Ads API unterstützt dies jedoch nicht. um zu verhindern, dass Felder versehentlich gelöscht werden. FieldMaskError.FIELD_HAS_SUBFIELDS Fehler.

# Creates a campaign with the proper resource name and an empty
# MaximizeConversions field.
my $campaign = Google::Ads::GoogleAds::V17::Resources::Campaign->new({
    resourceName =>
      Google::Ads::GoogleAds::V17::Utils::ResourceNames::campaign(
        $customer_id, $campaign_id
      ),
    maximizeConversions =>
      Google::Ads::GoogleAds::V17::Resources::MaximizeConversions->new()
    });

# Constructs an operation, using the FieldMasks' all_set_fields_of utility to
# derive the update mask. The field mask will include 'maximize_conversions',
# which will produce a FieldMaskError.FIELD_HAS_SUBFIELDS error.
my $campaign_operation =
  Google::Ads::GoogleAds::V17::Services::CampaignService::CampaignOperation->new({
    update     => $campaign,
    updateMask => all_set_fields_of($campaign)
  });

# Sends the operation in a mutate request that will result in a
# FieldMaskError.FIELD_HAS_SUBFIELDS error because empty object fields cannot
# be included in a field mask.
my $response = $api_client->CampaignService()->mutate({
    customerId => $customer_id,
    operations => [$campaign_operation]
  });

Das folgende Beispiel zeigt, wie Sie eine Kampagne ordnungsgemäß für die Verwendung des MaximizeConversions-Gebotsstrategie, ohne eines ihrer untergeordneten Felder festzulegen.

# Creates a campaign with the proper resource name.
my $campaign = Google::Ads::GoogleAds::V17::Resources::Campaign->new({
    resourceName => Google::Ads::GoogleAds::V17::Utils::ResourceNames::campaign(
      $customer_id, $campaign_id
    )
  });

# Creates a field mask from the existing campaign and adds all of the fields
# on the MaximizeConversions bidding strategy to the field mask. Because these
# fields are included in the field mask but excluded from the campaign object,
# the Google Ads API will set the campaign's bidding strategy to a
# MaximizeConversions object with none of its subfields set.
# Only include 'maximize_conversions.target_cpa_micros' in the field mask
# as it is the only mutable subfield on MaximizeConversions when used as a
# standard bidding strategy.
#
# Learn more about standard and portfolio bidding strategies here:
# https://developers.google.com/google-ads/api/docs/campaigns/bidding/assign-strategies
my $field_mask = all_set_fields_of($campaign);
push @{$field_mask->{paths}}, "maximize_conversions.target_cpa_micros";

# Creates an operation to update the campaign with the specified fields.
my $campaign_operation =
  Google::Ads::GoogleAds::V17::Services::CampaignService::CampaignOperation->new({
    update     => $campaign,
    updateMask => $field_mask
  });

Felder löschen

Felder können explizit gelöscht werden, indem sie wie gezeigt zur Feldmaske hinzugefügt werden. oder indem Sie das Feld auf einen leeren oder nicht definierten Wert setzen. Beispiel: Angenommen, Sie haben eine Kampagne mit der Gebotsstrategie „MaximizeConversions“ und für das Feld target_cpa_micros ein Wert größer als 0

# Creates a campaign with the proper resource name and a MaximizeConversions
# object with target_cpa_micros set to 0.
my $campaign =
  Google::Ads::GoogleAds::V17::Resources::Campaign->new({
    resourceName => Google::Ads::GoogleAds::V17::Utils::ResourceNames::campaign(
      $customer_id, $campaign_id
    ),
    maximizeConversions => Google::Ads::GoogleAds::V17::Resources::MaximizeConversions->new({
      targetCpaMicros => 0
    })
  });

# Constructs an operation, using the FieldMasks' all_set_fields_of utility to
# derive the update mask, which will include 'maximize_conversions.target_cpa_micros'.
my $campaign_operation =
  Google::Ads::GoogleAds::V17::Services::CampaignService::CampaignOperation->new({
    update     => $campaign,
    updateMask => all_set_fields_of($campaign)
  });

Beachten Sie, dass Felder mit verschachtelten Unterfeldern nur durch Löschen der folgenden den einzelnen Unterfeldern, wie in Objektfeldern mit definierten untergeordneten Felder.