Google Apps ScriptでGoogle Search Consoleの情報を取得する
更新日:2023.05.05
作成日:2017.02.12
検索ワードは、Google Search ConsoleでWeb管理画面からも確認できますが以下の制限があります。
- データは90日間しか保管されない
- 1000件までしか表示されない
これらの制限を回避するためには、Googleが提供するGoogle Search Console API
を利用して自分自身で取得する必要があります。
ここでは、Google Apps Scriptを利用してGoogle Sheetsに結果を出力する方法を紹介します。
手順
- GoogleAppsScriptを利用できるように追加する
- Google Search Console APIを有効化する
- 資格情報を作成
- OAuth2ライブラリの読込
- Google Apps Scriptに処理を記述する
- Developers ConsoleのRedirect URIを記述
Google Search Console APIを有効化する
data:image/s3,"s3://crabby-images/8291e/8291e0642b8ac6907f2a9995690f763841023995" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
data:image/s3,"s3://crabby-images/fa23c/fa23cd55435a77524d8b5d1a5b4c97d55f226548" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
資格情報を作成
data:image/s3,"s3://crabby-images/6f266/6f26693a281f875d89ab551894d1c5ebc148b82b" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
GoogleAppsScriptを利用できるように追加する
Google OAuth2ライブラリ追加
data:image/s3,"s3://crabby-images/57dbe/57dbe1055ed16cec7cfb2803fd4dd2dcd6c5278c" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
Resources > Libraryから1B7FSrk5Zi6L1rSxxTDgDEUsPzlukDsi4KGuTMorsTQHhGBzBkMun4iDF
を追加する。
data:image/s3,"s3://crabby-images/60f28/60f287126d4f1b943cf61b2a2464f42116da7a05" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
Versionを指定して、保存すればOKです。
data:image/s3,"s3://crabby-images/297dc/297dce749a1609eeb4bbbfc749272d1ac37c2eb1" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
Google Apps Scriptに処理を記述する
以下は、Google Search Consoleでデータ抽出して、Google Sheetsに書き込むサンプル。
実行方法は、まずopenSheet
を実行する。
data:image/s3,"s3://crabby-images/3885b/3885b69ae0af34503dd9f934e2734e646cb91a3d" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
その後、Logs
から認証用のリンクに飛んで、OAuth認証を行います。
data:image/s3,"s3://crabby-images/d6d40/d6d40c19cd8bbcdbef5d355c7d36bb24551f3556" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
var CLIENT_ID = '{YOUR_CLIENT_ID}';
var CLIENT_SECRET = '{YOUR_CLIENT_SECRET}';
var SITE_URL = 'https%3A%2F%2Fmeganii.com';
var PER_RECORD = 500;
var SHEET_ID = '{YOUR_SHEET_ID}';
function openSheet() {
var spreadsheet = SpreadsheetApp.openById(SHEET_ID);
var sheet = spreadsheet.getSheetByName("Sheet"); //この場合、あらかじめ「Sheet」シートを作成しておく
sheet.clear();
var response = query();
var json = JSON.parse(response.getContentText());
var rows = json["rows"];
// Add Header
sheet.getRange(1, 1).setValue("keys");
sheet.getRange(1, 2).setValue("clicks");
sheet.getRange(1, 3).setValue("ctr");
sheet.getRange(1, 4).setValue("impressions");
sheet.getRange(1, 5).setValue("position");
for (var i = 0; i < rows.length; i++) {
sheet.getRange(i+2, 1).setValue(rows[i]["keys"]);
sheet.getRange(i+2, 2).setValue(rows[i]["clicks"]);
sheet.getRange(i+2, 3).setValue(rows[i]["ctr"]);
sheet.getRange(i+2, 4).setValue(rows[i]["impressions"]);
sheet.getRange(i+2, 5).setValue(rows[i]["position"]);
Logger.log(rows);
}
}
function query() {
var date = new Date('2016-12-01');
var params = {
rowLimit: PER_RECORD,
startDate: '2016-10-01',
endDate: '2016-12-31',
dimensions: ["query"],
}
Logger.log(params);
var service = getService();
if(!service.hasAccess()){
alertAuth();
return;
}
var response = UrlFetchApp.fetch('https://www.googleapis.com/webmasters/v3/sites/'+ SITE_URL +'/searchAnalytics/query', {
method : "post",
contentType: "application/json",
headers: {
Authorization: 'Bearer ' + service.getAccessToken(),
},
payload:JSON.stringify(params),
});
Logger.log(response);
return response;
}
function alertAuth() {
var service = getService();
var authorizationUrl = service.getAuthorizationUrl();
Logger.log(authorizationUrl);
}
function getService() {
// Create a new service with the given name. The name will be used when
// persisting the authorized token, so ensure it is unique within the
// scope of the property store.
return OAuth2.createService('webmasters')
// Set the endpoint URLs, which are the same for all Google services.
.setAuthorizationBaseUrl('https://accounts.google.com/o/oauth2/auth')
.setTokenUrl('https://accounts.google.com/o/oauth2/token')
// Set the client ID and secret, from the Google Developers Console.
.setClientId(CLIENT_ID)
.setClientSecret(CLIENT_SECRET)
// Set the name of the callback function in the script referenced
// above that should be invoked to complete the OAuth flow.
.setCallbackFunction('authCallback')
// Set the property store where authorized tokens should be persisted.
.setPropertyStore(PropertiesService.getUserProperties())
// Set the scopes to request (space-separated for Google services).
.setScope('https://www.googleapis.com/auth/webmasters.readonly')
}
function authCallback(request) {
var service = getService();
var isAuthorized = service.handleCallback(request);
if (isAuthorized) {
return HtmlService.createHtmlOutput('認証に成功しました。タブを閉じてください。');
} else {
return HtmlService.createHtmlOutput('認証に失敗しました。タブを閉じてください。');
}
}
/**
* Reset the authorization state, so that it can be re-tested.
*/
function reset() {
var service = getService();
service.reset();
}
Google Apps Scriptの種類
Google Apps Scriptには2種類存在する。
- Container Bound Script
- Standalone Script
Container Bound Script
ExcelマクロのようなGoogle SheetsやDocsに対するスクリプトです。
data:image/s3,"s3://crabby-images/6a5fb/6a5fb378b23ca0070a7b478da1460d2eb797b6be" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
Standalone Script
data:image/s3,"s3://crabby-images/5ba2e/5ba2e2e0053c5b6d190ef7a7db6ef12c4407a962" alt="Google Apps ScriptでGoogle Search Consoleの情報を取得する"
Container Bound ScriptとStandalone Scriptの違い
Container Bound Script | Standalone Script | |
---|---|---|
作成方法 | 各コンテナ(Sheets,Forms,Sites)のメニューから作成 | Drive上またはhttps://script.google.com へアクセス |
Sheetsでの独自関数 | Spreadsheet上に作成すれば○ | ☓ |
onOpenトリガーの自動登録 | ○ | ☓ |
Webアプリケーションとして動作 | ○ | ○ |
ソースコードのダウンロード | ☓ | ○ |
ScriptEditor以外での開発 | ☓ | ○ |