use_proto_plus
yapılandırma parametresi ile kitaplığın proto-plus mesajları mı yoksa protobuf mesajları mı döndürmesini istediğinizi belirtebilirsiniz. Bu parametrenin nasıl ayarlanacağıyla ilgili ayrıntılar için yapılandırma dokümanlarına bakın.
Bu bölümde, kullanılacak ileti türlerinin performans üzerindeki etkileri açıklanmaktadır. Bu nedenle, bilinçli bir karar vermek için seçenekleri okuyup anlamanızı öneririz.
Proto-plus ve protobuf mesajları
Kod oluşturucu ardışık düzeni, protobuf mesaj arayüzünün ergonomisini iyileştirmek için proto-plus'ı entegre eder. Bu sayede, protobuf mesaj arayüzü yerel Python nesnelerine daha çok benzeyecek şekilde davranır. Ancak bu, proto-plus'ı kullanmanın performans yükü oluşturduğu anlamına gelir.
Proto-plus performansı
Proto-plus'ın temel avantajlarından biri, protobuf mesajlarını ve tanınmış türleri tür birleştirme adı verilen bir işlemle yerel Python türlerine dönüştürmesidir.
Marshaling, proto-plus mesaj örneğinde bir alana erişildiğinde, özellikle de bir protobuf tanımında bir alan okunduğunda veya ayarlandığında gerçekleşir:
syntax = "proto3";
message Dog {
string name = 1;
}
Bu tanım, proto-plus sınıfına dönüştürüldüğünde aşağıdaki gibi görünür:
import proto
class Dog(proto.Message):
name = proto.Field(proto.STRING, number=1)
Ardından Dog
sınıfını başlatabilir ve diğer Python nesnelerinde yaptığınız gibi name
alanına erişebilirsiniz:
dog = Dog()
dog.name = "Scruffy"
print(dog.name)
name
alanı okunup ayarlandığında değer, protobuf çalışma zamanında uyumlu olması için yerel bir Python str
türünden string
türüne dönüştürülür.
Performans analizlerimize göre, bu tür dönüşümleri gerçekleştirmek için harcanan sürenin performans üzerinde yeterince büyük bir etkisi olduğunu ve kullanıcıların protobuf mesajlarını kullanıp kullanmayacaklarına ihtiyaçlarına göre karar vermeleri gerektiğini belirledik.
Proto-plus ve protobuf mesajlarının kullanım alanları
- Proto-plus mesajı kullanım alanları
- Proto-plus, protobuf mesajlarına kıyasla ergonomik açıdan bir dizi iyileştirme sunar. Bu nedenle, bakımı yapılabilir ve okunabilir kod yazmak için idealdir. Yerel Python nesnelerini kullandıkları için daha kolay kullanılır ve anlaşılır.
- Protobuf mesajı kullanım alanları
- Performansa duyarlı kullanım alanları için protobuf'leri kullanın. Özellikle büyük raporları hızlı bir şekilde işlemesi gereken veya çok sayıda işlemle (ör.
BatchJobService
veyaOfflineUserDataJobService
) mutasyon istekleri oluşturan uygulamalarda bu yöntemi tercih edin.
Dinamik olarak değişen mesaj türleri
Uygulamanız için uygun mesaj türünü seçtikten sonra belirli bir iş akışı için diğer türü kullanmanız gerekebilir. Bu durumda, istemci kitaplığının sunduğu yardımcı programları kullanarak iki tür arasında dinamik olarak geçiş yapmak kolaydır. Yukarıdaki Dog
ileti sınıfını kullanarak:
from google.ads.googleads import util
# Proto-plus message type
dog = Dog()
# Protobuf message type
dog = util.convert_proto_plus_to_protobuf(dog)
# Back to proto-plus message type
dog = util.convert_protobuf_to_proto_plus(dog)
Protobuf mesaj arayüzü farklılıkları
Proto-plus arayüzü ayrıntılı olarak açıklanmıştır. Ancak burada, Google Ads istemci kitaplığının yaygın kullanım alanlarını etkileyen bazı önemli farklılıkları vurgulayacağız.
Bayt serileştirme
- Proto-plus mesajları
serialized = type(campaign).serialize(campaign) deserialized = type(campaign).deserialize(serialized)
- Protobuf mesajları
serialized = campaign.SerializeToString() deserialized = campaign.FromString(serialized)
JSON serileştirme
- Proto-plus mesajları
serialized = type(campaign).to_json(campaign) deserialized = type(campaign).from_json(serialized)
- Protobuf mesajları
from google.protobuf.json_format import MessageToJson, Parse serialized = MessageToJson(campaign) deserialized = Parse(serialized, campaign)
Alan maskeleri
api-core tarafından sağlanan alan maskesi yardımcı yöntemi, protobuf mesaj örneklerini kullanmak için tasarlanmıştır. Bu nedenle, proto-plus mesajlarını kullanırken yardımcıyı kullanmak için bunları protobuf mesajlarına dönüştürün:
- Proto-plus mesajları
from google.api_core.protobuf_helpers import field_mask campaign = client.get_type("Campaign") protobuf_campaign = util.convert_proto_plus_to_protobuf(campaign) mask = field_mask(None, protobuf_campaign)
- Protobuf mesajları
from google.api_core.protobuf_helpers import field_mask campaign = client.get_type("Campaign") mask = field_mask(None, campaign)
Sıralamalar
Proto-plus mesajları tarafından sunulan enum'lar, Python'un yerel enum
türündeki örneklerdir ve bu nedenle çeşitli kolaylık yöntemlerini devralır.
Enum türü alma
Listeleri almak için GoogleAdsClient.get_type
yöntemi kullanıldığında, döndürülen mesajlar proto-plus mı yoksa protobuf mesajları mı kullandığınıza bağlı olarak biraz farklıdır. Örneğin:
- Proto-plus mesajları
val = client.get_type("CampaignStatusEnum").CampaignStatus.PAUSED
- Protobuf mesajları
val = client.get_type("CampaignStatusEnum").PAUSED
Listeleri daha kolay almak için GoogleAdsClient
örneklerinde, kullandığınız mesaj türüne bakılmaksızın tutarlı bir arayüze sahip bir kolaylık özelliği bulunur:
val = client.enums.CampaignStatusEnum.PAUSED
Enum değeri alma
Bazen belirli bir enum'un değerini veya alan kimliğini bilmek yararlı olabilir. Örneğin, CampaignStatusEnum
üzerindeki PAUSED
, 3
ile eşleşir:
- Proto-plus mesajları
campaign = client.get_type("Campaign") campaign.status = client.enums.CampaignStatusEnum.PAUSED # To read the value of campaign status print(campaign.status.value)
- Protobuf mesajları
campaign = client.get_type("Campaign") status_enum = client.enums.CampaignStatusEnum campaign.status = status_enum.PAUSED # To read the value of campaign status print(status_enum.CampaignStatus.Value(campaign.status))
Enum adı alma
Bazen bir enum alanının adını bilmek yararlı olabilir. Örneğin, API'den nesneleri okurken int 3
değerinin hangi kampanya durumuna karşılık geldiğini bilmek isteyebilirsiniz:
- Proto-plus mesajları
campaign = client.get_type("Campaign") campaign.status = client.enums.CampaignStatusEnum.PAUSED # To read the name of campaign status print(campaign.status.name)
- Protobuf mesajları
campaign = client.get_type("Campaign") status_enum = client.enums.CampaignStatusEnum # Sets the campaign status to the int value for PAUSED campaign.status = status_enum.PAUSED # To read the name of campaign status status_enum.CampaignStatus.Name(campaign.status)
Yinelenen alanlar
proto-plus belgelerinde açıklandığı gibi, yinelenen alanlar genellikle yazılmış listelere eşdeğerdir. Yani neredeyse bir list
ile aynı şekilde çalışırlar.
Yinelenen skaler alanlara değer ekleme
Tekrarlanan skalar türünde alanlara (ör. string
veya int64
alanları) değer eklerken arayüz, mesaj türünden bağımsız olarak aynıdır:
- Proto-plus mesajları
ad.final_urls.append("https://www.example.com")
- Protobuf mesajları
ad.final_urls.append("https://www.example.com")
Buna diğer tüm yaygın list
yöntemleri de dahildir (ör. extend
):
- Proto-plus mesajları
ad.final_urls.extend(["https://www.example.com", "https://www.example.com/2"])
- Protobuf mesajları
ad.final_urls.extend(["https://www.example.com", "https://www.example.com/2"])
Yinelenen alanlara mesaj türleri ekleme
Tekrarlanan alan bir skalar tür değilse bu alanları tekrarlanan alanlara ekleme davranışı biraz farklıdır:
- Proto-plus mesajları
frequency_cap = client.get_type("FrequencyCapEntry") frequency_cap.cap = 100 campaign.frequency_caps.append(frequency_cap)
- Protobuf mesajları
# The add method initializes a message and adds it to the repeated field frequency_cap = campaign.frequency_caps.add() frequency_cap.cap = 100
Yinelenen alanlar atayın
Hem skaler hem de skaler olmayan yinelenen alanlar için alana listeleri farklı şekillerde atayabilirsiniz:
- Proto-plus mesajları
# In proto-plus it's possible to use assignment. urls = ["https://www.example.com"] ad.final_urls = urls
- Protobuf mesajları
# Protobuf messages do not allow assignment, but you can replace the # existing list using slice syntax. urls = ["https://www.example.com"] ad.final_urls[:] = urls
Boş mesajlar
Bazen bir ileti örneğinin bilgi içerip içermediğini veya alanlarının ayarlanıp ayarlanmadığını bilmek yararlı olabilir.
- Proto-plus mesajları
# When using proto-plus messages you can simply check the message for # truthiness. is_empty = bool(campaign) is_empty = not campaign
- Protobuf mesajları
is_empty = campaign.ByteSize() == 0
Mesaj metni
Hem proto-plus hem de protobuf mesajları için copy_from
üzerinde GoogleAdsClient
yardımcı yöntemini kullanmanızı öneririz:
client.copy_from(campaign, other_campaign)
Boş mesaj alanları
Boş mesaj alanları ayarlama işlemi, kullandığınız mesaj türüne bakılmaksızın aynıdır. Bunun için söz konusu alana boş bir mesaj kopyalamanız yeterlidir. Mesaj kopyası bölümünün yanı sıra Boş Mesaj Alanları kılavuzuna bakın. Boş bir mesaj alanı ayarlama örneğini aşağıda bulabilirsiniz:
client.copy_from(campaign.manual_cpm, client.get_type("ManualCpm"))
Ayrılmış kelime olan alan adları
Proto-plus mesajları kullanılırken, alan adları Python'da ayrılmış bir kelimeyse otomatik olarak sonuna alt çizgi eklenir. Asset
örneğiyle çalışma örneğini aşağıda bulabilirsiniz:
asset = client.get_type("Asset")
asset.type_ = client.enums.AssetTypeEnum.IMAGE
Ayrılmış adların tam listesi, gapic generator modülünde oluşturulur. Programatik olarak da erişilebilir.
Öncelikle modülü yükleyin:
python -m pip install gapic-generator
Ardından, bir Python REPL'de veya komut dosyasında:
import gapic.utils
print(gapic.utils.reserved_names.RESERVED_NAMES)
Sahada bulunma
Protobuf mesaj örneklerindeki alanların varsayılan değerleri olduğundan, bir alanın ayarlanıp ayarlanmadığını bilmek her zaman kolay değildir.
- Proto-plus mesajları
# Use the "in" operator. has_field = "name" in campaign
- Protobuf mesajları
campaign = client.get_type("Campaign") # Determines whether "name" is set and not just an empty string. campaign.HasField("name")
protobufMessage
sınıf arayüzünde, bir mesajdaki alanın varsayılan değere ayarlanmış olsa bile ayarlanıp ayarlanmadığını belirleyen bir HasField
yöntemi vardır.
Protobuf mesaj yöntemleri
Protobuf mesaj arayüzü, proto-plus arayüzünün bir parçası olmayan bazı kolaylık yöntemleri içerir. Ancak bir proto-plus mesajını protobuf eşdeğerine dönüştürerek bu yöntemlere kolayca erişebilirsiniz:
# Accessing the ListFields method
protobuf_campaign = util.convert_protobuf_to_proto_plus(campaign)
print(campaign.ListFields())
# Accessing the Clear method
protobuf_campaign = util.convert_protobuf_to_proto_plus(campaign)
print(campaign.Clear())
Sorun izleyici
Bu değişikliklerle ilgili sorularınız veya kitaplığın en yeni sürümüne geçişle ilgili sorununuz varsa takip aracımızda sorun kaydı oluşturun.