/google-trends-api

An API layer on top of google trends

Primary LanguageHTMLMIT LicenseMIT

#google-trends-api

NPM

npm version Build status Coverage Status Dependency Status Known Vulnerabilities

##Introduction This library provides an API layer to google trends data. It is constantly being expanded and improved so please check back frequently. Also, please feel free to contribute to make the library even better! 🐶

Simple to use:

var googleTrends = require('google-trends-api');

var options = {
	geo: 'country code or name',
	date: 'yyyymm',
	keywords: ['some', 'list', 'of', 'keywords'],
	category: 'some category',
	timePeriod: {
		type: enumerated string 'hour', 'day', 'month', or 'year'
		value: number
	}
}

googleTrends.apiMethod(options)
.then(function(results){
	console.log("Here are your google trend results!", results);
})
.catch(function(err){
	console.log("there was an error :(", err);
});

##Table of contents


Installation

To install this package, clone this git repository and include it in your project's node_modules or simply:

npm install google-trends-api

Require google-trends-api in your script and give it a variable name:

var googleTrends = require('google-trends-api');

You will now be able to access methods on googleTrends. See the API Methods section below to see the methods available and their syntax.

back to top


API

Promises

By default, all the API's return a promise for the results. Example:

googleTrends.topRelated('dog house')
.then(function(results){
  console.log(results);
})
.catch(function(err){
  console.error(err);
});

Would console.log:

[ { 'the dog house': '100',
    'the house': '100',
    'house of dog': '50',
    'dog house plans': '15',
    'dog training': '15',
    'dog house training': '15',
    'house train dog': '15',
    'build dog house': '10',
    'best house dog': '10',
    'dog houses': '10' } ]

Callbacks

All API methods can also take a callback function as the last input parameter. For example:

googleTrends.topRelated('dog house', function(err, results){
	if(err) console.error('there was an error!', err);
	else console.log(results);
})

Would console.log:

[ { 'the dog house': '100',
    'the house': '100',
    'house of dog': '50',
    'dog house plans': '15',
    'dog training': '15',
    'dog house training': '15',
    'house train dog': '15',
    'build dog house': '10',
    'best house dog': '10',
    'dog houses': '10' } ]

Examples

There are examples available for each API method that can be run by changing into the home google-trends directory and running node examples.js. Note: Each example in examples.js need to be uncommented.

API Methods

The following API methods are available:

  • trendData: returns the historical trend data to a provided keyword or an array of keywords - optionally accepts a timePeriod object
  • topRelated: returns terms that are most frequently searched with the term(s) you entered in the same search session, within the chosen category (optional) and country (optional). If you didn't enter a search term, top searches overall are shown.
  • risingSearches: returns terms that were searched for with the term you entered (or overall, if no keyword was entered), which had the most significant growth in volume in the requested time period. For each rising search term, you’ll see a percentage of the term’s growth compared to the previous time period. If you see “Breakout” instead of a percentage, it means that the search term grew by more than 5000%.
  • hotTrends: returns the current top 20 trending searches for a given location.
  • hotTrendsDetail: same as the hotTrends results except with more detail such as links, publication date, approximate traffic, etc.
  • top30in30: returns the top 30 searches in the past 30 days
  • allTopCharts: returns the top trending charts for a given date and location. Charts contain information such as title, description, source, a jumpFactory, etc.
  • categoryTopCharts: returns the top trending charts for a given category, date, and location.

For each of the API methods, rather than providing the parameters to the function in a specific order such as googleTrends.topRelated('keyword', 'country'), you can provide the function with an "options" object. Keys that are not required for the method are simply ignored. The available keys of the options object are as follows:

  • geo: 'country code provided as a string',
  • date: 'date provided in format yyyymm as a string where January starts at 01,
  • category: 'a string for a specific category',
  • keywords: 'either an array of keywords as strings or a singular keyword as a string'
  • timePeriod: an object with keys type and value where type's value is an enumerated string (either 'hour', 'day', 'month', or 'year') and value's value is a number. Note: this is the elapsed time up to the current time, for example {type: 'hour', value: 5} corresponds to data from 5 hours ago to now, or {type: 'day', value: 2} corresponds to data from 2 days ago to now

back to top


trendData()

Returns the historical trend data to a provided keyword or an array of keywords.

#####Syntax googleTrends.trendData(['keywords'], {type: 'string', value: number})

  • ['keywords'] - either an array of keywords as strings or a string with one keyword. If keywords is an array, the results will be returned in an array of the same order as the input. Entering a keyword is required.

  • {type: 'string', value: number} - the timePeriod object that must be formatted with keys type (which is an enumerated string of either 'hour', 'day', 'month', or 'year') and value (which is a number). Entering a timePeriod is optional. If no timePeriod object is provided, by default all past trend data will be returned, otherwise trend data for the given time period will be returned.

#####Example The following example provides the historical trend data for 'OJ Simpson'. Optionally, the input could have been provided as googleTrends.trendData({keywords: 'OJ Simpson'}).

######Input

googleTrends.trendData('OJ Simpson')
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.error(err);
});

######Output

[ { query: 'oj simpson',
    values:
     [ { date: '2003-12-01T05:00:00.000Z', value: 4 },
       { date: '2004-01-01T05:00:00.000Z', value: 4 },
       { date: '2004-02-01T05:00:00.000Z', value: 3 },
       { date: '2004-03-01T05:00:00.000Z', value: 4 },
       { date: '2004-04-01T05:00:00.000Z', value: 5 },
       { date: '2004-05-01T04:00:00.000Z', value: 7 },
       { date: '2004-06-01T04:00:00.000Z', value: 2 },
       { date: '2004-07-01T04:00:00.000Z', value: 2 },
       { date: '2004-08-01T04:00:00.000Z', value: 2 },
       { date: '2004-09-01T04:00:00.000Z', value: 4 },
       { date: '2004-10-01T04:00:00.000Z', value: 4 },
       { date: '2004-11-01T05:00:00.000Z', value: 3 },
       { date: '2004-12-01T05:00:00.000Z', value: 3 },
       ... more items ] } ]

#####Example The following example provides the historical trend data for 'swimming' and the 'olympics'. Optionally, the input could have been provided as googleTrends.trendData({keywords: ['swimming', 'olympics']}).

######Input

googleTrends.trendData(['swimming', 'olympics'])
.then(function(results){
  console.log(results);
})
.catch(function(err){
  console.error(err);
});

######Output

[ { query: 'swimming',
    values:
     [ { date: '2003-12-01T05:00:00.000Z', value: 7 },
       { date: '2004-01-01T05:00:00.000Z', value: 7 },
       { date: '2004-02-01T05:00:00.000Z', value: 7 },
       { date: '2004-03-01T05:00:00.000Z', value: 7 },
       { date: '2004-04-01T05:00:00.000Z', value: 8 },
       { date: '2004-05-01T04:00:00.000Z', value: 9 },
       { date: '2004-06-01T04:00:00.000Z', value: 10 },
       { date: '2004-07-01T04:00:00.000Z', value: 11 },
       { date: '2004-08-01T04:00:00.000Z', value: 7 },
       { date: '2004-09-01T04:00:00.000Z', value: 6 },
       { date: '2004-10-01T04:00:00.000Z', value: 5 },
       { date: '2004-11-01T05:00:00.000Z', value: 4 },
       { date: '2004-12-01T05:00:00.000Z', value: 6 },
       { date: '2005-01-01T05:00:00.000Z', value: 6 },
       { date: '2005-02-01T05:00:00.000Z', value: 6 },
       ... more items ] },
  { query: 'olympics',
    values:
     [ { date: '2003-12-01T05:00:00.000Z', value: 3 },
       { date: '2004-01-01T05:00:00.000Z', value: 4 },
       { date: '2004-02-01T05:00:00.000Z', value: 4 },
       { date: '2004-03-01T05:00:00.000Z', value: 4 },
       { date: '2004-04-01T05:00:00.000Z', value: 5 },
       { date: '2004-05-01T04:00:00.000Z', value: 5 },
       { date: '2004-06-01T04:00:00.000Z', value: 8 },
       { date: '2004-07-01T04:00:00.000Z', value: 66 },
       { date: '2004-08-01T04:00:00.000Z', value: 8 },
       { date: '2004-09-01T04:00:00.000Z', value: 3 },
       { date: '2004-10-01T04:00:00.000Z', value: 3 },
       ... more items ] } ]

#####Example The following example provides the historical trend data for 'OJ Simpson' for the past 5 days. Optionally, the input could have been provided as googleTrends.trendData('OJ Simpson', {type: 'day', value: 5}).

######Input

googleTrends.trendData({keywords: 'Oj Simpson', timePeriod: {type: 'day', value: 5}})
.then(function(results){
  console.log(results);
})
.catch(function(err){
  console.error(err);
});

######Output

[ { query: 'oj simpson',
    values:
     [ { date: '2016-10-17T21:00:00.000Z', value: 20 },
       { date: '2016-10-17T22:00:00.000Z', value: 18 },
       { date: '2016-10-17T23:00:00.000Z', value: 17 },
       { date: '2016-10-18T00:00:00.000Z', value: 23 },
       { date: '2016-10-18T01:00:00.000Z', value: 20 },
       { date: '2016-10-18T02:00:00.000Z', value: 22 },
       { date: '2016-10-18T03:00:00.000Z', value: 19 },
       { date: '2016-10-18T04:00:00.000Z', value: 15 },
       { date: '2016-10-18T05:00:00.000Z', value: 11 },
       { date: '2016-10-18T06:00:00.000Z', value: 8 },
       { date: '2016-10-18T07:00:00.000Z', value: 7 },
       { date: '2016-10-18T08:00:00.000Z', value: 7 },
       { date: '2016-10-18T09:00:00.000Z', value: 6 },
       { date: '2016-10-18T10:00:00.000Z', value: 7 },
       { date: '2016-10-18T11:00:00.000Z', value: 7 },
       { date: '2016-10-18T12:00:00.000Z', value: 10 },
       { date: '2016-10-18T13:00:00.000Z', value: 10 },
       { date: '2016-10-18T14:00:00.000Z', value: 10 },
       { date: '2016-10-18T15:00:00.000Z', value: 11 },
       { date: '2016-10-18T16:00:00.000Z', value: 13 },
       { date: '2016-10-18T17:00:00.000Z', value: 13 },
       { date: '2016-10-18T18:00:00.000Z', value: 18 },
       { date: '2016-10-18T19:00:00.000Z', value: 16 },
       { date: '2016-10-18T20:00:00.000Z', value: 16 },
       { date: '2016-10-18T21:00:00.000Z', value: 19 },
       { date: '2016-10-18T22:00:00.000Z', value: 33 },
       { date: '2016-10-18T23:00:00.000Z', value: 81 },
       { date: '2016-10-19T00:00:00.000Z', value: 100 },
       { date: '2016-10-19T01:00:00.000Z', value: 30 },
       ... more items ] } ]

back to top


topRelated()

Returns terms that are most frequently searched with the term you entered in the same search session, within the chosen category (optional) and country (optional). If you didn't enter a search term, top searches overall are shown

#####Syntax googleTrends.topRelated(['keywords'], {type: 'string', value: number}, 'country')

  • ['keywords'] - either an array of keywords as strings or a string with one keyword. If keywords is an array, the results will be returned in an array of the same order as the input. If no keyword is entered, top searches overall are shown

  • {type: 'string', value: number} - the timePeriod object that must be formatted with keys type (which is an enumerated string of either 'hour', 'day', 'month', or 'year') and value (which is a number). Entering a timePeriod is optional. If no timePeriod object is provided, by default all past data will be used

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default

#####Example The following example provides the top related keywords to 'dog house' in the 'US'. Optionally, the input could have been provided as googleTrends.topRelated({keywords: 'dog house', geo: 'US'}). Order of the keys does not matter.

######Input

googleTrends.topRelated('dog house', 'US')
.then(function(results){
  console.log(results);
})
.catch(function(err){
  console.error(err);
});

######Output

[ { 'the dog house': '100',
    'the house': '100',
    'house of dog': '50',
    'dog house plans': '15',
    'dog training': '15',
    'dog house training': '15',
    'house train dog': '15',
    'build dog house': '10',
    'best house dog': '10',
    'dog houses': '10' } ]

back to top


risingSearches()

Returns terms that were searched for with the term you entered (or overall, if no keyword was entered), which had the most significant growth in volume in the requested time period. For each rising search term, you’ll see a percentage of the term’s growth compared to the previous time period. If you see “Breakout” instead of a percentage, it means that the search term grew by more than 5000%.

#####Syntax googleTrends.risingSearches(['keywords'], {type: 'string', value: number}, 'country')

  • ['keywords'] - either an array of keywords as strings or a string with one keyword. If keywords is an array, the results will be returned in an array of the same order as the input. If no keyword is entered, top searches overall are shown

  • {type: 'string', value: number} - the timePeriod object that must be formatted with keys type (which is an enumerated string of either 'hour', 'day', 'month', or 'year') and value (which is a number). Entering a timePeriod is optional. If no timePeriod object is provided, by default all past data will be used

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default

#####Example The following example provides the top related keywords to 'dog house' in the 'US'. Optionally, the input could have been provided as googleTrends.risingSearches({keywords: 'dog house', geo: 'US'}). Order of the keys does not matter.

######Input

googleTrends.risingSearches('dog house', 'US')
.then(function(results){
  console.log(results);
})
.catch(function(err){
  console.error(err);
});

######Output

[ { 'little dog house': '+250%',
    'dog house grill': '+140%',
    'large dog house': '+90%',
    'best house dog': '+80%',
    'hot dog house': '+70%',
    'the dog house': '+70%',
    'the house': '+70%',
    'house of dog': '+50%',
    'house train dog': '+40%' } ]

back to top


hotTrends()

Returns the current top 20 trending searches for a given location

#####Syntax googleTrends.hotTrends('country')

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default.

#####Example The following example provides the top 20 trending searches in the 'US'. Optionally, the input could have been provided as googleTrends.hotTrends({geo: 'US'}). Any other keys provided in the object will be ignore.

######Input

googleTrends.hotTrends('US')
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.log(err);
});

######Output

[ 'Donald Drumpf',
  'Mark Ruffalo',
  'Ashley Graham',
  'Raspberry Pi 3',
  'Oscars 2016',
  'Why is there a leap day',
  'Brie Larson',
  'Alicia Vikander',
  'Mark Rylance',
  'Room',
  'Stacey Dash',
  'Mad Max Fury Road',
  'merkin',
  'Alejandro González Iñárritu',
  'Sam Smith',
  'The Big Short',
  'The Hateful Eight',
  'Jennifer Lawrence',
  'Why Does Leap Year Have 366 Days',
  'Inside Out' ];

back to top


hotTrendsDetail()

Returns the current top 20 trending searches for a given location with more detail than the hotTrends() method

#####Syntax googleTrends.hotTrendsDetail('country')

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default.

#####Example The following example provides the top 20 trending searches in the 'US'. Optionally, the input could have been provided as googleTrends.hotTrendsDetail({geo: 'US'}). Any other keys provided in the object will be ignore.

######Input

googleTrends.hotTrendsDetail('US')
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.log(err);
});

######Output Note: Only showing some returned data for brevity

{ rss:
   { '$':
      { version: '2.0',
        'xmlns:ht': 'http://www.google.com/trends/hottrends',
        'xmlns:atom': 'http://www.w3.org/2005/Atom' },
     channel:
      [ { title: [ 'Hot Trends' ],
          link: [ 'http://www.google.us/trends/hottrends?pn=p1' ],
          'atom:link':
           [ { '$':
                { href: 'http://www.google.us/trends/hottrends/atom/feed?pn=p1',
                  rel: 'self',
                  type: 'application/rss+xml' } } ],
          description: [ 'Recent hot searches' ],
          item:
           [ { title: [ 'Melania Trump' ],
               description: [ '' ],
               link: [ 'http://www.google.us/trends/hottrends?pn=p1#a=20160301-Melania+Trump' ],
               pubDate: [ 'Tue, 01 Mar 2016 01:00:00 -0800' ],
               'ht:picture': [ '//t2.gstatic.com/images?q=tbn:ANd9GcT9MS12TcSh5cRqw6CGr7FXqTELrlqBPY-f6Nnpksa_Duy753wXe8jq1Q_fl9DVFRYqEHFW3BLA' ],
               'ht:picture_source': [ 'Politico (blog)' ],
               'ht:approx_traffic': [ '100,000+' ],
               'ht:news_item':
                [ { 'ht:news_item_title': [ '<b>Melania Trump</b> goes on the attack' ],
                    'ht:news_item_snippet': [ '<b>Melania Trump</b> said Marco Rubio&#39;s campaign has taken a “desperate tone” toward Donald Trump, but the Republican front-runner&#39;s wife is unbothered. Rubio finally engaged Donald Trump at last Thursday&#39;s Republican debate and hasn&#39;t let up since,&nbsp;...' ],
                    'ht:news_item_url': [ 'http://www.politico.com/blogs/2016-gop-primary-live-updates-and-results/2016/03/melania-trump-marco-rubio-220015' ],
                    'ht:news_item_source': [ 'Politico (blog)' ] },
                  { 'ht:news_item_title': [ '<b>Melania Trump</b>: &#39;Donald will change tone if he becomes president&#39;' ],
                    'ht:news_item_snippet': [ 'Her comments came during a CNN interview with Anderson Cooper in which the host brought up the frequent insults fired between the Republican presidential candidates and the criticism Donald <b>Trump</b> has received for his tone on the campaign trail.' ],
                    'ht:news_item_url': [ 'http://www.independent.co.uk/news/people/melania-trump-donald-will-change-tone-if-he-becomes-president-a6904786.html' ],
                    'ht:news_item_source': [ 'The Independent' ] } ] },
                    ...

back to top


top30in30()

Returns the top 30 searches in the past 30 days

#####Syntax googleTrends.top30in30()

  • top30in30 does not take in parameters

#####Example The following example returns the top 30 searches in the past 30 days.

######Input

googleTrends.top30in30()
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.log(err);
});

######Output Note: Only showing some returned data for brevity

{
  "summaryMessage": "Showing top 30 searches in past 30 days",
  "dataUpdateTime": 1456776000,
  "weekDaysList": [
    {
      "title": "Sun"
    },
    {
      "title": "Mon"
    },
    {
      "title": "Tue"
    },
    {
      "title": "Wed"
    },
    {
      "title": "Thu"
    },
    {
      "title": "Fri"
    },
    {
      "title": "Sat"
    }
  ],
  "monthsList": [
    {
      "title": "January",
      "height": 1
    },
    {
      "title": "February",
      "height": 4
    }
  ],
  "weeksList": [
    {
      "daysList": [
        {
          "date": "20160131",
          "formattedDate": "31",
          "longFormattedDate": "January 31",
          "data": {
            "numOfAdditionalTrends": 19,
            "trend": {
              "title": "Frederick Douglass",
              "titleLinkUrl": "/search?q=frederick+douglass",
              "relatedSearchesList": [],
              "formattedTraffic": "10,000,000+",
              "trafficBucketLowerBound": 10000000,
              "hotnessLevel": 5,
              "hotnessColor": "#d04108",
              "imgUrl": "//t0.gstatic.com/images?q=tbn:ANd9GcRCCrM-fy25_79vt3P5YBXG_nZyhK4zya6kP5oMDSyts5WRMMlhxdUBtTKKVnFLgu2C0qXL6iU",
              "imgSource": "CNN International",
              "imgLinkUrl": "http://www.cnn.com/2016/02/01/living/frederick-douglass-google-doodle-black-history-month-feat/index.html",
              "newsArticlesList": [
                {
                  "title": "Who&#39;s <b>Frederick Douglass</b>? Learn more about civil rights leader and movement",
                  "link": "http://www.cnn.com/2016/02/01/living/frederick-douglass-google-doodle-black-history-month-feat/index.html",
                  "source": "CNN International",
                  "snippet": "His autobiography &quot;Narrative of the Life of <b>Frederick Douglass</b>, An American&quot; is a good place to start. &quot;Ain&#39;t I a Woman?&quot; Former slave Sojourner Truth told of the horror as an African-American woman in slavery in &quot;Ain&#39;t I a Woman?&quot; the speech she gave <b>...</b>"
                },
                {
                  "title": "<b>Frederick Douglass</b>: America&#39;s great abolitionist",
                  "link": "http://www.csmonitor.com/USA/Society/2016/0201/Frederick-Douglass-America-s-great-abolitionist",
                  "source": "Christian Science Monitor",
                  "snippet": "<b>Frederick</b> Augustus Washington Bailey was born into slavery in Maryland early in the 19th century. After beginning his life on a plantation, <b>Douglass</b> was sent to Baltimore, where he was first exposed to the alphabet and literacy. Allowing slaves to <b>...</b>"
                }
              ],
              "startTime": 1454302800,
              "shareUrl": "https://www.google.com/trends/hottrends?stt=Frederick+Douglass&std=20160131&pn=p1#a=20160131-Frederick+Douglass",
              "date": "20160131",
              "exploreUrl": "/trends/explore#q=frederick+douglass&date=today+1-m&geo=US"
            }
          }
        },
        ...

back to top


allTopCharts()

Returns the top trending charts for a given date and location

#####Syntax googleTrends.allTopCharts('date', 'country')

  • date - an optional string provided as 'yyyymm'. January === 01, December === 12. Note that google does not aggregate the data for the current month, so the date provided must always be at least one month behind. If no date is provided, the most recent date available is assumed.

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default.

#####Example The following example provides the top charts in January 2016 in the 'US'. Optionally, the input could have been provided as googleTrends.allTopCharts({geo: 'US', date: '201601'}). Order of the keys does not matter.

######Input

googleTrends.allTopCharts('201601', 'US')
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.log(err);
});

######Output Note: Only showing some returned data for brevity

{
  "summaryMessage": "Showing all charts",
  "prevTimePeriod": "201512",
  "nextTimePeriod": "",
  "isMonthlyTimePeriod": true,
  "data": {
    "chartList": [
      {
        "trendingChart": {
          "entityList": [
            {
              "title": "David Bowie",
              "titleLength": 11,
              "description": {
                "description": "David Robert Jones, known as David Bowie, was an English singer, songwriter and musician, who also worked as an actor and record producer...",
                "source": "Wikipedia",
                "sourceUrl": "http://en.wikipedia.org/wiki/David_Bowie"
              },
              "shareUrl": "http://www.google.com/trends/topcharts?vm=trendingchart&cid=actors&date=201601&geo=US&cat&mid=/m/01vsy7t",
              "twitterShareUrlTitle": "David Bowie #1 in Google Trends Actors trending chart",
              "idForTracking": "David Bowie",
              "exploreUrl": "/trends/explore#cmpt=q&q=/m/01vsy7t&date=1/2016+1m&geo=US",
              "jumpFactorSummary": "+3,700%",
              "topChartRank": 1,
              "titleLinkUrl": "/search?q=David+Bowie"
            },
            {
              "title": "Alan Rickman",
              "titleLength": 12,
              "description": {
                "description": "Alan Sidney Patrick Rickman, was an English actor and director, known for playing a variety of roles on stage and screen...",
                "source": "Wikipedia",
                "sourceUrl": "http://en.wikipedia.org/wiki/Alan_Rickman"
              },
              "shareUrl": "http://www.google.com/trends/topcharts?vm=trendingchart&cid=actors&date=201601&geo=US&cat&mid=/m/09y20",
              "twitterShareUrlTitle": "Alan Rickman #2 in Google Trends Actors trending chart",
              "idForTracking": "Alan Rickman",
              "exploreUrl": "/trends/explore#cmpt=q&q=/m/09y20&date=1/2016+1m&geo=US",
              "jumpFactorSummary": "+7,500%",
              "topChartRank": 2,
              "titleLinkUrl": "/search?q=Alan+Rickman"
            },
            ...

back to top


categoryTopCharts()

Returns the top trending charts for a given category, date and location

#####Syntax googleTrends.categoryTopCharts('category', 'date', 'country')

  • category - a specific category provided as a string that you wish to search for. category is a required parameter.

  • date - an optional string provided as 'yyyymm'. January === 01, December === 12. Note that google does not aggregate the data for the current month, so the date provided must always be at least one month behind. If no date is provided, the most recent date available is assumed.

  • country - an optional string for the country. Although the library can figure out the country from a formal name, it is preferred that the country is provided as a country code, for example, 'united states' should be provided as 'US', 'japan' should be provided as 'JP', etc. If no country code is provided, 'US' is assumed by default.

#####Example The following example provides the top charts for actors in January 2016 in the 'US'. Optionally, the input could have been provided as googleTrends.categoryTopCharts({category: 'actors', geo: 'US', date: '201601'}). Order of the keys does not matter.

######Input

googleTrends.categoryTopCharts('actors', '201601', 'US')
.then(function(results){
	console.log(results);
})
.catch(function(err){
	console.log(err);
});

######Output Note: Only showing some returned data for brevity

{
  "data": {
    "entityList": [
      {
        "title": "David Bowie",
        "titleLength": 11,
        "description": {
          "description": "David Robert Jones, known as David Bowie, was an English singer, songwriter and musician, who also worked as an actor and record producer...",
          "source": "Wikipedia",
          "sourceUrl": "http://en.wikipedia.org/wiki/David_Bowie"
        },
        "shareUrl": "http://www.google.com/trends/topcharts?vm=trendingchart&cid=actors&date=201601&geo=US&cat&mid=/m/01vsy7t",
        "twitterShareUrlTitle": "David Bowie #1 in Google Trends Actors trending chart",
        "idForTracking": "David Bowie",
        "exploreUrl": "/trends/explore#cmpt=q&q=/m/01vsy7t&date=1/2016+1m&geo=US",
        "jumpFactorSummary": "+3,700%",
        "topChartRank": 1,
        "titleLinkUrl": "/search?q=David+Bowie"
      },
      {
        "title": "Alan Rickman",
        "titleLength": 12,
        "description": {
          "description": "Alan Sidney Patrick Rickman, was an English actor and director, known for playing a variety of roles on stage and screen...",
          "source": "Wikipedia",
          "sourceUrl": "http://en.wikipedia.org/wiki/Alan_Rickman"
        },
        "shareUrl": "http://www.google.com/trends/topcharts?vm=trendingchart&cid=actors&date=201601&geo=US&cat&mid=/m/09y20",
        "twitterShareUrlTitle": "Alan Rickman #2 in Google Trends Actors trending chart",
        "idForTracking": "Alan Rickman",
        "exploreUrl": "/trends/explore#cmpt=q&q=/m/09y20&date=1/2016+1m&geo=US",
        "jumpFactorSummary": "+7,500%",
        "topChartRank": 2,
        "titleLinkUrl": "/search?q=Alan+Rickman"
      },
      ...

back to top


##Potential errors

  • Entering an incorrect or invalid country code will result in the following error: 'Could not locate country'
  • Entering an invalid date will result in the following error: 'Date is invalid'
  • If a required field is not provided, the following error will be returned: FIELD must be provided
  • Exceeding the quota limits from google will result in the following error: 'Quota limit exceeded, try again later'

back to top