How to get a list of most popular pages from Google Analytics in Python?
data:image/s3,"s3://crabby-images/2a304/2a3042a29ea43efcef9c8d0d58aeba1bfffff3a7" alt="Vera Mazhuga"
Vera Mazhuga
Software DeveloperLet's look at how to get a list of most popular pages from Google Analytics using Python (Django).
Let's suppose that we have a website and we want to show in our home page a list of 10 most visited pages of our website for the last month.
Create a project in Google Analytics and obtain a tracking code
Firstly, we need to create a project in
Google Analytics and obtain a code to place on all pages of our website.
Go to
Google Analytics website and enter the Admin section:
data:image/s3,"s3://crabby-images/3132a/3132abc8c568f196c9bc5a5b75d3809e5a8f0ab9" alt=""
Then you'll need to create a new property for your account:
data:image/s3,"s3://crabby-images/ce716/ce716155ac99499fd53a529093c490a76eaacfad" alt=""
Enter a data related to your website: name, url, category and a timezone:
data:image/s3,"s3://crabby-images/b00a6/b00a6ba42e80b1fd89c67d2826e6659ceddb8a74" alt=""
The you need to copy your tracking code and include it to all pages of your website:
data:image/s3,"s3://crabby-images/bc17e/bc17e38b29fa1ae3e2fcb0a52c2db9ea4aa12aee" alt=""
Create a project in Google Console and get a secret key
Then we'll need to enter a
Google Console and create a new project:
data:image/s3,"s3://crabby-images/2e6bc/2e6bc756445d6ffa564124a95d26c36e1a335813" alt=""
Then we'll need to activate Google Analytics API for our project:
data:image/s3,"s3://crabby-images/8be5d/8be5de4215f4792df0978645b20244061a0fd156" alt=""
Next, we'll create a new client ID:
data:image/s3,"s3://crabby-images/ac19b/ac19b54e536c38c5bedf4fa55a668f1b7ec78aca" alt=""
Since we are planning to connect in "offline" mode (via Python code), we'll select a
Service account:
data:image/s3,"s3://crabby-images/d0c01/d0c017a6b891589072c8427168db4a6f69748837" alt=""
Right after clicking on "Create Client ID" button, we'll get file "
.p12" with a secret code:
data:image/s3,"s3://crabby-images/cf651/cf651fa32006fe343681c5bc2230350efc6c1920" alt=""
And email that we'll use to connect to API via our Python code:
data:image/s3,"s3://crabby-images/598e2/598e2f25041c6d6b32f6ebed8297babb4e8532e3" alt=""
Allow access to Google Analytics
Since we have a "
...@developer.gserviceaccount.com" email, we can add it to the list of users that can have access to Analytics of our website:
data:image/s3,"s3://crabby-images/65066/65066a2b8b116eeed88f6b50695feb4d061d8876" alt=""
data:image/s3,"s3://crabby-images/c2787/c27879dde858cac314c0dfcfad26aa6494ec3475" alt=""
The last thing we need to do on this step is to copy the ID of our project from Google Analytics:
data:image/s3,"s3://crabby-images/8da37/8da3731f5e0b8e6c774e95ae2712bb0367b46480" alt=""
Getting data from Python code
In order to be able to access
Google Analytics API from our Python code firstly, we need to install the following packages: google-api-python-client
, oauth2client
and python-gflags
.
import httplib2
import os
import datetime
from django.conf import settings
from apiclient.discovery import build
from oauth2client.client import SignedJwtAssertionCredentials
# Email of the Service Account.
SERVICE_ACCOUNT_EMAIL ='12345@developer.gserviceaccount.com'
# Path to the Service Account's Private Key file.
SERVICE_ACCOUNT_PKCS12_FILE_PATH = os.path.join(
settings.BASE_DIR,
'53aa9f98bb0f8535c34e5cf59cee0f32de500c82-privatekey.p12',
)
def get_analytics():
f = file(SERVICE_ACCOUNT_PKCS12_FILE_PATH, 'rb')
key = f.read()
f.close()
credentials = SignedJwtAssertionCredentials(
SERVICE_ACCOUNT_EMAIL,
key,
scope='https://www.googleapis.com/auth/analytics.readonly',
)
http = httplib2.Http()
http = credentials.authorize(http)
service = build('analytics', 'v3', http=http)
end_date = datetime.date.today()
# 30 days ago
start_date = end_date - datetime.timedelta(days=30)
data_query = service.data().ga().get(**{
'ids': 'ga:123456', # the code of our project in Google Analytics
'dimensions': 'ga:pageTitle,ga:pagePath',
'metrics': 'ga:pageviews,ga:uniquePageviews',
'start_date': start_date.strftime('%Y-%m-%d'),
'end_date': end_date.strftime('%Y-%m-%d'),
'sort': '-ga:pageviews',
})
analytics_data = data_query.execute()
return analytics_data
You can experiment with different query options using
Google Analytics Query Explorer.
data:image/s3,"s3://crabby-images/b4ddd/b4ddd2560e37523b993a208e23c845eb46ebed44" alt=""
Image was taken from NASA.
Written by Vera Mazhuga
data:image/s3,"s3://crabby-images/2a304/2a3042a29ea43efcef9c8d0d58aeba1bfffff3a7" alt="Vera Mazhuga"
Vera specializes in writing and maintaining code for various applications. Her focus on problem-solving and efficient programming ensures reliable and effective software solutions.