| #!/usr/bin/python |
| # -*- coding: utf-8 -*- |
| # |
| # Copyright 2014 Google Inc. All Rights Reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| """Simple intro to using the Google Analytics API v3. |
| |
| This application demonstrates how to use the python client library to access |
| Google Analytics data. The sample traverses the Management API to obtain the |
| authorized user's first profile ID. Then the sample uses this ID to |
| contstruct a Core Reporting API query to return the top 25 organic search |
| terms. |
| |
| Before you begin, you must sigup for a new project in the Google APIs console: |
| https://code.google.com/apis/console |
| |
| Then register the project to use OAuth2.0 for installed applications. |
| |
| Finally you will need to add the client id, client secret, and redirect URL |
| into the client_secrets.json file that is in the same directory as this sample. |
| |
| Sample Usage: |
| |
| $ python hello_analytics_api_v3.py |
| |
| Also you can also get help on all the command-line flags the program |
| understands by running: |
| |
| $ python hello_analytics_api_v3.py --help |
| """ |
| from __future__ import print_function |
| |
| __author__ = "[email protected] (Nick Mihailovski)" |
| |
| import sys |
| |
| from googleapiclient.errors import HttpError |
| from googleapiclient import sample_tools |
| from oauth2client.client import AccessTokenRefreshError |
| |
| |
| def main(argv): |
| # Authenticate and construct service. |
| service, flags = sample_tools.init( |
| argv, |
| "analytics", |
| "v3", |
| __doc__, |
| __file__, |
| scope="https://www.googleapis.com/auth/analytics.readonly", |
| ) |
| |
| # Try to make a request to the API. Print the results or handle errors. |
| try: |
| first_profile_id = get_first_profile_id(service) |
| if not first_profile_id: |
| print("Could not find a valid profile for this user.") |
| else: |
| results = get_top_keywords(service, first_profile_id) |
| print_results(results) |
| |
| except TypeError as error: |
| # Handle errors in constructing a query. |
| print(("There was an error in constructing your query : %s" % error)) |
| |
| except HttpError as error: |
| # Handle API errors. |
| print( |
| ( |
| "Arg, there was an API error : %s : %s" |
| % (error.resp.status, error._get_reason()) |
| ) |
| ) |
| |
| except AccessTokenRefreshError: |
| # Handle Auth errors. |
| print( |
| "The credentials have been revoked or expired, please re-run " |
| "the application to re-authorize" |
| ) |
| |
| |
| def get_first_profile_id(service): |
| """Traverses Management API to return the first profile id. |
| |
| This first queries the Accounts collection to get the first account ID. |
| This ID is used to query the Webproperties collection to retrieve the first |
| webproperty ID. And both account and webproperty IDs are used to query the |
| Profile collection to get the first profile id. |
| |
| Args: |
| service: The service object built by the Google API Python client library. |
| |
| Returns: |
| A string with the first profile ID. None if a user does not have any |
| accounts, webproperties, or profiles. |
| """ |
| |
| accounts = service.management().accounts().list().execute() |
| |
| if accounts.get("items"): |
| firstAccountId = accounts.get("items")[0].get("id") |
| webproperties = ( |
| service.management() |
| .webproperties() |
| .list(accountId=firstAccountId) |
| .execute() |
| ) |
| |
| if webproperties.get("items"): |
| firstWebpropertyId = webproperties.get("items")[0].get("id") |
| profiles = ( |
| service.management() |
| .profiles() |
| .list(accountId=firstAccountId, webPropertyId=firstWebpropertyId) |
| .execute() |
| ) |
| |
| if profiles.get("items"): |
| return profiles.get("items")[0].get("id") |
| |
| return None |
| |
| |
| def get_top_keywords(service, profile_id): |
| """Executes and returns data from the Core Reporting API. |
| |
| This queries the API for the top 25 organic search terms by visits. |
| |
| Args: |
| service: The service object built by the Google API Python client library. |
| profile_id: String The profile ID from which to retrieve analytics data. |
| |
| Returns: |
| The response returned from the Core Reporting API. |
| """ |
| |
| return ( |
| service.data() |
| .ga() |
| .get( |
| ids="ga:" + profile_id, |
| start_date="2012-01-01", |
| end_date="2012-01-15", |
| metrics="ga:visits", |
| dimensions="ga:source,ga:keyword", |
| sort="-ga:visits", |
| filters="ga:medium==organic", |
| start_index="1", |
| max_results="25", |
| ) |
| .execute() |
| ) |
| |
| |
| def print_results(results): |
| """Prints out the results. |
| |
| This prints out the profile name, the column headers, and all the rows of |
| data. |
| |
| Args: |
| results: The response returned from the Core Reporting API. |
| """ |
| |
| print() |
| print("Profile Name: %s" % results.get("profileInfo").get("profileName")) |
| print() |
| |
| # Print header. |
| output = [] |
| for header in results.get("columnHeaders"): |
| output.append("%30s" % header.get("name")) |
| print("".join(output)) |
| |
| # Print data table. |
| if results.get("rows", []): |
| for row in results.get("rows"): |
| output = [] |
| for cell in row: |
| output.append("%30s" % cell) |
| print("".join(output)) |
| |
| else: |
| print("No Rows Found") |
| |
| |
| if __name__ == "__main__": |
| main(sys.argv) |