Google udostępnia bibliotekę klienta Pythona do interakcji z interfejsem Ad Manager API. Zalecamy używanie biblioteki klienta z PyPI.
Aby rozpocząć, utwórz nowy projekt w wybranym środowisku IDE lub dodaj zależność do istniejącego projektu. Google publikuje artefakty biblioteki klienta w PyPI jako google-ads-admanager
.
pip install google-ads-admanager
Konfigurowanie danych logowania
Biblioteka klienta Pythona używa do uwierzytelniania protokołu OAuth 2 i domyślnych danych logowania aplikacji (ADC).
ADC wyszukuje dane logowania w tych miejscach:
- zmiennej środowiskowej
GOOGLE_APPLICATION_CREDENTIALS
. - Dane logowania użytkownika skonfigurowane za pomocą interfejsu wiersza poleceń Google Cloud (gcloud CLI).
- W przypadku uruchamiania w Google Cloud – konto usługi powiązane ze zasobem Google Cloud.
Informacje o tworzeniu i konfigurowaniu danych logowania ADC znajdziesz w sekcji Uwierzytelnianie.
Przesyłanie pierwszej prośby
Każda usługa ma obiekt ServiceClient
z metodami synchronicznymi i asynchronicznymi dla każdej metody REST. W tym przykładzie odczytujemy za pomocą funkcji asynchronicznej Network
.
from google.ads import admanager_v1
def sample_get_network():
# Create a client
client = admanager_v1.NetworkServiceClient()
# Initialize request argument(s)
request = admanager_v1.GetNetworkRequest(
name="networks/[NETWORK_CODE]",
)
# Make the request
response = client.get_network(request=request)
# Handle the response
print(response)
Przykłady innych metod i zasobów znajdziesz w repozytorium GitHub googleapis/google-cloud-python
.
Rejestrowanie żądań i odpowiedzi HTTP
Biblioteka klienta w Pythonie korzysta ze standardowej biblioteki Pythona logging
do rejestrowania żądań i odpowiedzi HTTP. Domyślnie logowanie jest wyłączone.
Aby włączyć rejestrowanie, ustaw zmienną środowiskową GOOGLE_SDK_PYTHON_LOGGING_SCOPE
. Ta zmienna środowiskowa konfiguruje obsługę rejestrowania zdarzeń na poziomie logging.DEBUG
lub wyższym.
# Log only Ad Manager API events
export GOOGLE_SDK_PYTHON_LOGGING_SCOPE=google.ads.admanager_v1
# Log all Google library events
export GOOGLE_SDK_PYTHON_LOGGING_SCOPE=google
Możesz też użyć modułu Pythona logging
:
import logging
from google.ads import admanager_v1
logger = logging.getLogger("google.ads.admanager_v1")
logger.addHandler(logging.StreamHandler())
logger.setLevel(logging.DEBUG)
Obsługuj błędy
Wszystkie błędy interfejsu API rozszerzają klasę podstawową GoogleAPIError
.
Pole przyczyna błędu jednoznacznie identyfikuje typy błędów. Użyj tego pola, aby określić sposób postępowania z błędem.
try:
network = client.get_network(request=request)
print(network)
except GoogleAPIError as e:
# Handle error
print(e.reason)
Błędy interfejsu API Ad Manager zawierają też unikalny identyfikator requestId
, który możesz podać zespołowi pomocy, aby uzyskać pomoc w rozwiązywaniu problemów. W tym przykładzie z GoogleAPIError
jest wyodrębniany element requestId
.
except GoogleAPIError as e:
requestInfoType = "type.googleapis.com/google.rpc.RequestInfo"
requestInfo = [detail for detail in e.details if detail['@type'] == requestInfoType][0]
print(requestInfo['requestId'])
Konfigurowanie ustawień serwera proxy
Biblioteka klienta Pythona uwzględnia ustawienia zmiennych środowiskowych http_proxy
i https_proxy
.