The new Search Ads 360 Reporting API is now available. Join the searchads-api-announcements Google group to stay up to date on upcoming enhancements and releases.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-28 UTC."],[[["\u003cp\u003eThis code sample demonstrates how to retrieve customer client details using the Search Ads 360 API.\u003c/p\u003e\n"],["\u003cp\u003eIt utilizes a search query to retrieve customer client data including descriptive name, customer ID, and status.\u003c/p\u003e\n"],["\u003cp\u003eExamples are provided in both Python and Java, showcasing how to interact with the API in different programming languages.\u003c/p\u003e\n"],["\u003cp\u003eYou need to provide your Search Ads 360 customer ID as an argument when running the code.\u003c/p\u003e\n"]]],["The provided code examples demonstrate how to retrieve customer client information from Search Ads 360 using both Python and Java. They establish a connection to the Search Ads 360 service, construct a query to select the descriptive name, client customer ID, and status from `customer_client`, and use `customer_id` and `login_customer_id` to search. Finally the examples print the results, such as the customer client's name, customer ID, and status, for each returned row.\n"],null,["# Get CustomerClient\n\n### Python\n\n\n```python\n#!/usr/bin/env python\n# Copyright 2022 Google LLC\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# https://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\"\"\"Retrieves customer_client for a customer using a pagination search request.\n\"\"\"\n\nimport argparse\nimport traceback\nfrom google.ads.searchads360.v0.services.types.search_ads360_service import SearchSearchAds360Request\nfrom util_searchads360 import SearchAds360Client\n\n\ndef main(client, customer_id) -\u003e None:\n search_ads_360_service = client.get_service()\n\n query = \"\"\"\n SELECT\n customer_client.descriptive_name,\n customer_client.client_customer,\n customer_client.status\n FROM customer_client\"\"\"\n\n request = SearchSearchAds360Request()\n request.customer_id = customer_id\n request.query = query\n\n # Issues a search request.\n results = search_ads_360_service.search(request=request)\n\n for row in results:\n customer_client = row.customer_client\n print(\n f\"CustomerClient found with name {customer_client.descriptive_name}, customer {customer_client.client_customer}, and status: {customer_client.status.name}\"\n )\n\n\nif __name__ == \"__main__\":\n # SearchAds360Client will read the search-ads-360.yaml configuration file in\n # the home directory if none is specified.\n search_ads_360_client = SearchAds360Client.load_from_file()\n\n parser = argparse.ArgumentParser(\n description=(\"Retrieves customer_client for a customer.\"))\n # Arguments to provide to run the example.\n parser.add_argument(\n \"-c\",\n \"--customer_id\",\n type=str,\n required=True,\n help=\"The Search Ads 360 customer ID (10 digits, no dashes).\",\n )\n\n parser.add_argument(\n \"-l\",\n \"--login_customer_id\",\n type=str,\n required=False,\n help=\"The Search Ads 360 login customer ID (10 digits, no dashes).\",\n )\n\n args = parser.parse_args()\n\n search_ads_360_client.set_ids(args.customer_id, args.login_customer_id)\n\n try:\n main(search_ads_360_client, args.customer_id)\n except Exception: # pylint: disable=broad-except\n traceback.print_exc()\n```\n\n\u003cbr /\u003e\n\n[Download get_customer_client.py](/static/search-ads/reporting/sample-code/get_customer_client.py)\n\n### Java\n\n\n```java\n// Copyright 2022 Google LLC\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n// https://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\npackage sample;\n\nimport com.beust.jcommander.Parameter;\nimport com.google.ads.searchads360.v0.lib.SearchAds360Client;\nimport com.google.ads.searchads360.v0.resources.CustomerClient;\nimport com.google.ads.searchads360.v0.services.SearchAds360Row;\nimport com.google.ads.searchads360.v0.services.SearchAds360ServiceClient;\nimport com.google.ads.searchads360.v0.services.SearchAds360ServiceClient.SearchPagedResponse;\nimport com.google.ads.searchads360.v0.services.SearchSearchAds360Request;\n\n/** Get customer client details. */\npublic class GetCustomerClient {\n private static class GetCustomerClientParams extends CodeSampleParams {\n\n @Parameter(names = \"--customerId\", required = true)\n private String customerId;\n\n @Parameter(names = \"--loginCustomerId\")\n private String loginCustomerId;\n }\n\n public static void main(String[] args) {\n GetCustomerClientParams params = new GetCustomerClientParams();\n if (!params.parseArguments(args)) {\n // Optional: You may pass the loginCustomerId on the command line or specify a loginCustomerId\n // here (10 digits, no dashes). If neither are set, customerId will be used as\n // loginCustomerId.\n // params.loginCustomerId = Long.parseLong(\"INSERT_LOGIN_CUSTOMER_ID_HERE\");\n }\n final String loginCustomerId = params.loginCustomerId;\n final String customerId = params.customerId;\n\n try {\n // Creates a SearchAds360Client with the specified loginCustomerId. If there's\n // no loginCustomerId, customerId will be used instead.\n final SearchAds360Client searchAds360Client =\n SearchAds360Client.newBuilder()\n .setLoginCustomerId(loginCustomerId == null ? customerId : loginCustomerId)\n .fromPropertiesFile()\n .build();\n // Creates the Search Ads 360 Service client.\n SearchAds360ServiceClient client = searchAds360Client.create();\n new GetCustomerClient().runExample(client, customerId);\n } catch (Exception exception) {\n System.err.printf(\"Failed with exception: %s%n\", exception);\n exception.printStackTrace();\n System.exit(1);\n }\n }\n\n private void runExample(SearchAds360ServiceClient searchAds360ServiceClient, String customerId) {\n // Creates a query that retrieves all child accounts of the customerId specified in search\n // calls below.\n String query =\n \"\"\"\n SELECT\n customer_client.descriptive_name, customer_client.client_customer, customer_client.status\n FROM customer_client\n \"\"\";\n SearchSearchAds360Request request =\n SearchSearchAds360Request.newBuilder().setCustomerId(customerId).setQuery(query).build();\n\n // Issues a search request.\n final SearchPagedResponse searchPagedResponse = searchAds360ServiceClient.search(request);\n for (SearchAds360Row element : searchPagedResponse.iterateAll()) {\n CustomerClient customerClient = element.getCustomerClient();\n System.out.printf(\n \"CustomerClient found with name '%s', customer %s, and status: %s.%n\",\n customerClient.getDescriptiveName(),\n customerClient.getClientCustomer(),\n customerClient.getStatus());\n }\n }\n}\n```\n\n\u003cbr /\u003e\n\n[Download GetCustomerClient.java](/static/search-ads/reporting/sample-code/GetCustomerClient.java)"]]