How to get data from Google analytics api for different websites - google-analytics

Google analytics api for different websites for example:
I have 67 websites and there record in Google analytics.
Actually I want single website Top 10 links most visited, with numbers of times that link is visited and total website visits and search engine visits.
I have used GAPI but it doesn't show for specific website :
$ga = new gapi('xxxxx#gmail.com', 'xxxxxxx');
$dimensions = array('browser','source','region');
$metrics = array('pageViews','visitors','visits');
$ga->requestReportData('12312123', $dimensions, $metrics, '-visits');
$gaResults = $ga->getResults();
if you have answer for Google analytics with zend framework2,you can answer for this Question

I Found Solution My Own:
Account detail that cantain you websites:
$ga = new gapi('xxxxx#gmail.com', 'xxxxxxx');
give dimension and metrics that you want from google analytic
$dimensions = array('browser','source','region');
$metrics = array('pageViews','visitors','visits');
Each website in google analytics have a profile_id:123456
You can see it by login in to your account.
$ga->requestReportData(profile_id, $dimensions, $metrics, '-visits');
you will retrive data for specific website

Related

Google Analytics UserID API extraction

Trying to extract a userID from GoogleAnalytics. This is to view which user is the using the website most and least.
I would to retrieve the top 5 user IDs and bottom 5 user IDs that were passed using either:
gtag('config', 'GA_TRACKING_ID', {
'user_id': 'USER_ID'
});
OR
using a custom dimension... ( https://support.google.com/analytics/answer/2709828?hl=en )
I'm (vaguely) aware of policies and TOS to keep 'non identifying' information on Google BUT there are posts online indicating you can link back to CMS data.
Steps so far
Google Analytics with UserID and view setup - Working in Google dashboard and showing filtered userID and All website data using the idea.
Requirements:
Extract page view and session data for each userId between a date
range (or all by default)
UserID via standard GA method
UserID via Custom dimension method
Any help, pointers or examples how someone has completed something like this are appreciated.
NOTE: This is to PULL data out of GA and manipulate/display it on an external system/dashboard.
Seen this which states it's not possible: Google analytics userID tracking
and this which states it (kind of) is google analytics API implementation for tracking a specific user activities in php
The solution I used:
Tracking
Create Google Analytics account
Create a new view by activating the UserID tracking (labeled NewView1)
Use https://developers.google.com/analytics/devguides/collection/gtagjs/custom-dims-mets
i.e. Define your custom dimension
Get Analytics tracking code + Add custom definition code
Create a Custom report using the 'metrics' you want to see and filtering by the 'custom dimension' I created earlier.
(note: data took ~ 12 hours to be visible so don't expect to work instantly)
Front end tracking additions
gtag('config', 'GA_TRACKING_ID', {
'custom_map': {'dimension<Index>': 'dimension_name'}
});
// Sends the custom dimension to Google Analytics.
gtag('event', 'any_event_name', {'dimension_name': dimension_value});
Extraction
Create New Google Developer Console Project (API)
Use a Service Account to connect the API with Analytics ( https://developers.google.com/analytics/devguides/reporting/core/v4/quickstart/service-php ) -- API -> credentials -> Create Credentials (Service Account key)
(assign role [mine was set to Project => View])
Save the Text file to your filesystem and rename to json as per examples
Add permissions to your Analytics project by copy/pasting the 'Email' from the Service account details into Analytics User Management.
Get the view ID of the data you wish to extract (Analtyics created in step 2 in tracking)
Use the sample Code (HelloAnalytics.php) to connect and extract data
Use your custom dimension to filter results
The dimension filter I used was $dimensions (see below)
...
$dimensions = new \Google_Service_AnalyticsReporting_Dimension();
$dimensions->setName('ga:dimension1'); // as per docs
// Create the ReportRequest object.
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics(array($sessions, $pageviews));
$request->setDimensions($dimensions);
From there I was able to see the same data via API that I could see in the custom report on analytics web.
NOTE: be careful of which Google project and view you're in while setting up
permissions and dimensions.
NOTE: using gtag() code and not Universal (ga()) js code
The answer is a very brief/rough summary of how I achieved my specific goal. It is not a one-size-fits all solution but hopefully it will give someone a better idea of how to set and extract custom variable data within Google.
The final result was data from the API. From there it's up to you.

google analytics demographics intrest overview fetch

I want to get all the data from google analytics. Can you please explain how to get data of "isitors-demographics-interest-overview"
Affinity Category
In-Market Segmen
Other Category0.00% of total users
I used some codes to get data from google analatics but i am stuck on "intrest menu"
$age = Analytics::performQuery($pobj, 'data', ['metrics' => 'ga:users','dimensions' => 'ga:userAgeBracket']);
$google['age'] = $age;
/*gender*/
$gender = Analytics::performQuery($pobj, 'data', ['metrics' => 'ga:users','dimensions' => 'ga:userGender']);
$google['gender'] = $gender;
The google analytics API is not related to the Google analytics website. The google analytics website has set up reports that have been processed internally.
you can not get ALL your google analytics data unless you have a premium account in that case you can request that it be exported to BigQuery.
You can not get the interest menu report directly. Your going to have to build up the data yourself using the dimensions and metrics available

Why is Analytics Reporting Api data not matching with Google Analytics Dashboard?

I am working on an analytics module which pulls data from Google Analytics, Facebook and Twitter Analytics api.
Using Analytics Reporting Api V4 to pull the data from Google Analytics.
Total number of sessions value does not match with what I see on Dashboard. I am using metric ga:sessions to pull the number of sessions.
In some cases, the number of sessions coming from reporting api matches with Dashboard. But not all the time. I am finding it hard to get it approved from QA without a proper explanation.
I checked dimension filters and reporting query multiple times but couldn't find anything wrong with it.
Added the samplingLevel to my report request but still seeing the same result.
ReportRequest totalNumberOfSessions = new ReportRequest().setViewId(VIEW_ID)
.setDateRanges(Arrays.asList(lifetime))
.setDimensions(Arrays.asList(custom))
.setDimensionFilterClauses(Arrays.asList(clause))
.setMetrics(Arrays.asList(sessions))
.setSamplingLevel("LARGE");
According to https://developers.google.com/analytics/devguides/reporting/core/v4/samples, use setSegments instead of setDimensionFilterClauses.
Like this:
String path = "<your_path>";
SegmentDimensionFilter exactPathDimensionFilter = new SegmentDimensionFilter()
.setDimensionName("ga:pagePath").setOperator("EXACT")
.setExpressions(Arrays.asList(path));
SegmentFilterClause exactPathSegmentFilterClause = new SegmentFilterClause()
.setDimensionFilter(exactPathDimensionFilter);
OrFiltersForSegment orFiltersForSegment = new OrFiltersForSegment()
.setSegmentFilterClauses(Arrays.asList(exactPathSegmentFilterClause));
SimpleSegment simpleSegment = new SimpleSegment()
.setOrFiltersForSegment(Arrays.asList(orFiltersForSegment));
SegmentFilter segmentFilter = new SegmentFilter()
.setSimpleSegment(simpleSegment);
SegmentDefinition segmentDefinition = new SegmentDefinition()
.setSegmentFilters(Arrays.asList(segmentFilter));
DynamicSegment dynamicSegment = new DynamicSegment().setSessionSegment(
segmentDefinition).setName("Path pageviews");
Segment segment = new Segment().setDynamicSegment(dynamicSegment);
ReportRequest request = new ReportRequest().setViewId(VIEW_ID)
.setDateRanges(Arrays.asList(dateRange))
.setMetrics(Arrays.asList(metric))
.setDimensions(Arrays.asList(new Dimension().setName("ga:segment")))
.setSegments(Arrays.asList(segment));
This example uses a path filter. You should change it according to your "clause" variable.

Why data i get from google analytics API not match with google analytics web interface?

I used Google API to get data from google analytics, but the metrics not the same with the web interface of google analytics.
ie: I get data on 2015-03-01 - It return pageviews 79
But on web interface of google analytics, it is 80.
I had searched on some question the same me, but almost them show the way to solve is Sampling level.
I tried to set other Sampling level
DataResource.GaResource.GetRequest request = Service.Data.Ga.Get(profileId, startDate.ToString("yyyy-MM-dd"),
endDate.ToString("yyyy-MM-dd"), string.Join(",", metrics));
if (dimensions != null)
{
request.Dimensions = string.Join(",", dimensions);
}
request.SamplingLevel = DataResource.GaResource.GetRequest.SamplingLevelEnum.HIGHERPRECISION;
request.StartIndex = startIndex;
return request;
after that, the result return the same before, it not change.
So, anyone know this issue?
Simple its sampled data vs. unsampled data which you can read about here: https://support.google.com/analytics/answer/1042498?hl=en
For API work i normally use a web query explorer to verify that my API call's are being sent and responses match to verify the data: https://ga-dev-tools.appspot.com/explorer/

How to fetch the current session's utm parameters in Google Analytics

Let's say a user gets to one of my pages with all the utm data (utm_campaign, etc.). On the page they land, a session is created in Google Analytics with all this info.
Then, they browse my site and get to another page. On that page, the utm_campaign isn't in the query string anymore.
Is there a way I can fetch the utm_campaign data?
Please note I use Universal Analytics, so it's ga instead of _gaq.
UPDATE: In case anyone is wondering, this code doesn't work:
ga(function(tracker) {
alert(tracker.get('campaignName'));
alert(tracker.get('campaignSource'));
alert(tracker.get('campaignMedium'));
alert(tracker.get('campaignKeyword'));
alert(tracker.get('campaignContent'));
alert(tracker.get('campaignId'));
});

Resources