Bu kılavuzda, Google Ads API için Perl istemci kitaplığını kullanmanın temelleri açıklanmaktadır.
İstemciyi başlatma
Kitaplığı kullanmaya başlamak için Google::Ads::GoogleAds::Client örneği oluşturun. İstemci, Yapılandırma kılavuzunda ayrıntılı olarak açıklandığı gibi çeşitli şekillerde yapılandırılabilir. Yaygın bir yaklaşım, googleads.properties dosyası kullanmaktır:
use Google::Ads::GoogleAds::Client;
my $api_client = Google::Ads::GoogleAds::Client->new();
Hizmet oluştur
İstemci başlatıldıktan sonra çeşitli API hizmetlerinin örneklerini oluşturabilirsiniz. Örneğin, kampanyalarla etkileşim kurmak için bir CampaignService örneği oluşturursunuz:
my $campaign_service = $api_client->CampaignService();
API çağrısı yapma
Kampanyaları almak için API çağrısı yapma örneğini aşağıda bulabilirsiniz. Bu snippet, istemcinin başlatılmasını, hizmet oluşturulmasını ve bir yöntemin çağrılmasını gösterir.
use strict;
use warnings;
use Google::Ads::GoogleAds::Client;
use Google::Ads::GoogleAds::V22::Services::GoogleAdsService::SearchGoogleAdsRequest;
# Initialize the Google Ads client. See the [Configuration guide](configuration) for more options.
my $api_client = Google::Ads::GoogleAds::Client->new();
# Get the GoogleAdsService.
my $google_ads_service = $api_client->GoogleAdsService();
# Specify the customer ID and query.
my $customer_id = "INSERT_CUSTOMER_ID_HERE";
my $query = "SELECT campaign.name, campaign.status FROM campaign";
# Create a search request.
my $search_request = Google::Ads::GoogleAds::V22::Services::GoogleAdsService::SearchGoogleAdsRequest
->new({
customerId => $customer_id,
query => $query
});
# Execute the search request.
my $search_response = $google_ads_service->search($search_request);
# Iterate over the results and print campaign names.
foreach my $google_ads_row (@{$search_response->{results}}) {
printf "Campaign with resource name '%s' and name '%s'.\n",
$google_ads_row->{campaign}->{resourceName},
$google_ads_row->{campaign}->{name};
}
Hataları işleme
API çağrıları istisnalara neden olabilir. eval
blokları içinde Google::Ads::GoogleAds::GoogleAdsException yakalamak ve işlemek için API çağrılarınızı sarmalamanız gerekir.
use strict;
use warnings;
use Google::Ads::GoogleAds::Client;
use Google::Ads::GoogleAds::GoogleAdsException;
use Google::Ads::GoogleAds::V22::Services::GoogleAdsService::SearchGoogleAdsRequest;
my $api_client = Google::Ads::GoogleAds::Client->new();
my $google_ads_service = $api_client->GoogleAdsService();
my $customer_id = "INSERT_CUSTOMER_ID_HERE";
my $query = "SELECT campaign.name, campaign.status FROM campaign";
my $search_request = Google::Ads::GoogleAds::V22::Services::GoogleAdsService::SearchGoogleAdsRequest->new({
customerId => $customer_id,
query => $query
});
eval {
my $search_response = $google_ads_service->search($search_request);
# Process successful response.
foreach my $google_ads_row (@{$search_response->{results}}) {
printf "Campaign name: %s\n", $google_ads_row->{campaign}->{name};
}
};
if ($@) {
if (blessed($@) && $@->isa('Google::Ads::GoogleAds::GoogleAdsException')) {
my $exception = $@;
printf "A Google Ads exception occurred:\n";
printf " Request ID: %s\n", $exception->get_request_id();
foreach my $error (@{$exception->get_errors()}) {
printf " Error code: %s\n", $error->{errorCode};
printf " Message: %s\n", $error->{message};
}
} else {
# Print other types of exceptions.
print "An error occurred: $@\n";
}
}
Diğer örnekleri inceleyin
Örnekler bölümünde birkaç faydalı kod örneği bulabilirsiniz.
Örneklerin çoğunda parametreler gerekir. Parametreleri bağımsız değişken olarak iletebilir (önerilir) veya kaynak kodundaki INSERT_XXXXX_HERE değerlerini düzenleyebilirsiniz. Bir örneğin kullanım ifadesini görmek için -help öğesini komut satırı bağımsız değişkeni olarak iletin.
perl examples/basic_operations/get_campaigns.pl -help