GAS(Google Apps Script)は、Googleの豊富なサービスと連携してタスクを自動化する強力なツールです
本記事では、初めてGASを試す方、特にスタンドアロン型の使い方に興味を持っている方に向けて、スタンドアロン型とコンテナバインド型の違いを解説し、スタンドアロン型で実際に簡単なコードを紹介したいと思います!
GASは、環境構築がいらず、基本言語がJavaScriptで構成されているため、初心者におすすめのプログラミング言語なのですが、「何から始めたらいいの?」とお悩みの方もいるかと思います
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
本記事では実際に仕事でGASを扱っている私が、このような悩みを抱えている方に向けて、GASについて解説していきたいと思います!
今回はいよいよ、GASを使って簡単なコードを書いていこうと思います!
data:image/s3,"s3://crabby-images/bfd8d/bfd8d61bff1ed17dc914434a8426111467578eca" alt=""
data:image/s3,"s3://crabby-images/bfd8d/bfd8d61bff1ed17dc914434a8426111467578eca" alt=""
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
「そもそもGASって何?」という方はまずは上の記事を読んでみてください!
スタンドアロン型とコンテナバインド型の違い
GASにはスタンドアロン型とコンテナバインド型があります
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
簡単に言えばGASが単独で存在するのか、Googleサービスに紐づいて存在するのかといった違いです
スタンドアロン型は独立したアプリケーションのために使用し、コンテナバインド型は特定のGoogle Apps内のカスタマイズや拡張機能のために使用します
使用ケースに応じて適切なプロジェクトタイプを選ぶようにしましょう!
【今回のメイン】スタンドアロン型
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
単純にアクセスするだけならばコンテナバインド型の方が簡単だけど、あえてスタンドアロン型でやってみよう!
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
難しそう…
data:image/s3,"s3://crabby-images/81f6b/81f6b1509da66a0c2e29928c8d2d255ea5c79979" alt=""
data:image/s3,"s3://crabby-images/81f6b/81f6b1509da66a0c2e29928c8d2d255ea5c79979" alt=""
data:image/s3,"s3://crabby-images/81f6b/81f6b1509da66a0c2e29928c8d2d255ea5c79979" alt=""
今後、GASを勉強していく上で複数サービスを同一のGASから操作する場合は、自ずとスタンドアロン型の記述が必要となってくるからこの機会にチャレンジしてみよう!
事前準備
今回は、Googleスプレッドシート
、Googleドキュメント
、Googleスライド
、Googleフォーム
それぞれにアクセスしますので、以下のような状態を作ってください!
data:image/s3,"s3://crabby-images/f3db0/f3db0465da3f292ac9b6d6a98d8378c126b28931" alt=""
data:image/s3,"s3://crabby-images/f3db0/f3db0465da3f292ac9b6d6a98d8378c126b28931" alt=""
新規に各種サービスを作成する場合、サービスを開いたあとに適当な入力を一度でもすれば、ヘッダー部の表示が変わり、Googleドライブへの保存が完了します
data:image/s3,"s3://crabby-images/6b260/6b2607c91e43ebd2dbaa7bb5fbd05ddc7daef0ce" alt=""
data:image/s3,"s3://crabby-images/6b260/6b2607c91e43ebd2dbaa7bb5fbd05ddc7daef0ce" alt=""
data:image/s3,"s3://crabby-images/d8123/d81232c63469464f278a228a1b9611246f4d16ec" alt=""
data:image/s3,"s3://crabby-images/d8123/d81232c63469464f278a228a1b9611246f4d16ec" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
自動保存は本当に便利です!
各ファイルのIDを取得する
Googleスプレッドシート
、Googleドキュメント
、Googleスライド
、Googleフォーム
にはそれぞれに一意なID(文字、数字、ハイフン、アンダースコアから成る一意の値)が割り振られています。この一意のIDはファイルのURLから確認できますので、それを取得(コピー) しておいてください。
data:image/s3,"s3://crabby-images/13fa4/13fa4d86f506ce04cdb1fac7eeb95ace7e646c94" alt=""
data:image/s3,"s3://crabby-images/13fa4/13fa4d86f506ce04cdb1fac7eeb95ace7e646c94" alt=""
※この例でいうと、四角で囲った1xjdjN2uJefWlyN87SScPsnahWJ_NEVEuHiDxxBElPdU
がIDとなります
GASエディタを開く
data:image/s3,"s3://crabby-images/39e68/39e68a672091d440f102d710962f3365c802c9dd" alt=""
data:image/s3,"s3://crabby-images/39e68/39e68a672091d440f102d710962f3365c802c9dd" alt=""
data:image/s3,"s3://crabby-images/25065/250651b3bfdb8d84ffeae09c8607cc1dae26d2d4" alt=""
data:image/s3,"s3://crabby-images/25065/250651b3bfdb8d84ffeae09c8607cc1dae26d2d4" alt=""
data:image/s3,"s3://crabby-images/fb6fd/fb6fd8c866765be92c4a0f719f921b4d5948348b" alt=""
data:image/s3,"s3://crabby-images/fb6fd/fb6fd8c866765be92c4a0f719f921b4d5948348b" alt=""
data:image/s3,"s3://crabby-images/9c6a5/9c6a5b5cc4aef2ce9e6a75ad75c3ecc821de9303" alt="画像に alt 属性が指定されていません。ファイル名: dutsnd5-1-1024x378.png"
data:image/s3,"s3://crabby-images/9c6a5/9c6a5b5cc4aef2ce9e6a75ad75c3ecc821de9303" alt="画像に alt 属性が指定されていません。ファイル名: dutsnd5-1-1024x378.png"
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
エディタを開くのは思いのほか簡単なんだね!
わっ…なんか「▷実行」を押したら承認?を求められちゃった…
data:image/s3,"s3://crabby-images/3bfec/3bfec441b8ca1762be0151728ab2c00242c808dd" alt=""
data:image/s3,"s3://crabby-images/3bfec/3bfec441b8ca1762be0151728ab2c00242c808dd" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
プロジェクトを開始する時、必ず出てくる画面だね
「権限を確認」をクリックしよう!
data:image/s3,"s3://crabby-images/2f065/2f065b20a552c2795797962507f959f5fa0f3e58" alt=""
data:image/s3,"s3://crabby-images/2f065/2f065b20a552c2795797962507f959f5fa0f3e58" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
自分のアカウントを選択したら「このアプリはGoogleで確認されていません」って出てきちゃったよ?
data:image/s3,"s3://crabby-images/db96f/db96ffbe8e5f740220aa93bb86f272483f150e97" alt=""
data:image/s3,"s3://crabby-images/db96f/db96ffbe8e5f740220aa93bb86f272483f150e97" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
「詳細」をクリックして、「無題のプロジェクト(安全ではないページ)に移動」をクリックしてみて!
data:image/s3,"s3://crabby-images/2f207/2f207d8047f474877942693104b84623c5d7ce1e" alt=""
data:image/s3,"s3://crabby-images/2f207/2f207d8047f474877942693104b84623c5d7ce1e" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
「許可」をクリックしました!
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
data:image/s3,"s3://crabby-images/1351b/1351b891c199cb0fef048efde678a3a878f1d8e3" alt=""
これでGASを書く準備が整ったよ!
早速、試しに色々書いていこう!
Googleスプレッドシートを編集する
function gaslog_SpreadSheet() {
// スプレッドシートクラスを用いて、IDを指定してファイルにアクセスする
let wSpread = SpreadsheetApp.openById('自分のスプレッドシートのIDを貼り付け');
// 対象スプレッドシートの1番目のシートにアクセスする
let wSheet = wSpread.getSheets()[0];
// "シート1"にアクセスする場合など名称確定の場合は、以下でもOK
// let wSheet = wSpread.getSheetByName('シート1');
// 試しにC2セル(2行3列目)にがすぴょんと入力する
wSheet.getRange(2, 3).setValue('がすぴょん');
}
data:image/s3,"s3://crabby-images/56b75/56b75907d48315da8ce75f48e1f830cd58a05bbd" alt=""
data:image/s3,"s3://crabby-images/56b75/56b75907d48315da8ce75f48e1f830cd58a05bbd" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
「実行」をクリック!
data:image/s3,"s3://crabby-images/d4828/d482849f9d31136d2fb69f4eb6e2e354c643f06f" alt=""
data:image/s3,"s3://crabby-images/d4828/d482849f9d31136d2fb69f4eb6e2e354c643f06f" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
わっ…すごい!
C2セルに僕の名前が入力されたよ!
小ネタ「セル」を選択する方法
data:image/s3,"s3://crabby-images/85254/852549b8e29aa2987deb4ee1f65d65886287ef14" alt=""
data:image/s3,"s3://crabby-images/85254/852549b8e29aa2987deb4ee1f65d65886287ef14" alt=""
data:image/s3,"s3://crabby-images/d7b72/d7b727aa5b1f5d79e38c87fe231c3a3865f8bb0d" alt=""
data:image/s3,"s3://crabby-images/d7b72/d7b727aa5b1f5d79e38c87fe231c3a3865f8bb0d" alt=""
Google スプレッドシートのクラス一覧
Googleドキュメントを編集する
function gaslog2_Document() {
// ドキュメントクラスを用いて、IDを指定してファイルにアクセスする
let wDocument = DocumentApp.openById('自分のGoogleドキュメントのIDを貼り付け');
// 試しに、対象ドキュメントに段落を追加して「がすぴょん」と入力する
wDocument.getBody().appendParagraph('がすぴょん');
}
data:image/s3,"s3://crabby-images/49dd4/49dd40366f51fc848086484a2fd1ba62f8c00894" alt=""
data:image/s3,"s3://crabby-images/49dd4/49dd40366f51fc848086484a2fd1ba62f8c00894" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
上記のプログラムを実行すると、対象ドキュメントに「がすぴょん」と出力されます。
data:image/s3,"s3://crabby-images/d82eb/d82ebe4fb68b569ecbcce94648f8df068908258d" alt=""
data:image/s3,"s3://crabby-images/d82eb/d82ebe4fb68b569ecbcce94648f8df068908258d" alt=""
Googleドキュメントのクラス一覧
Googleスライドを編集する
function gaslog3_Slide() {
// スライドクラスを用いて、IDを指定してファイルにアクセスする
let wSlides = SlidesApp.openById('自分のGoogleスライドのIDを貼り付け');
// スライドの1ページ目を取得する
let wSlide = wSlides.getSlides()[0];
// 試しに1ページ目に設定されているテキストボックスや図形オブジェクトの数を取得する
console.log(wSlide.getShapes().length);
// 1ページ目の1つ目のオブジェクトに「がすぴょん」と設定する
wSlide.getShapes()[0].getText().setText('がすぴょん');
}
data:image/s3,"s3://crabby-images/62d77/62d774b441275023d16019b3b7564569d376f2de" alt=""
data:image/s3,"s3://crabby-images/62d77/62d774b441275023d16019b3b7564569d376f2de" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
タイトルが僕の名前に書き換わった!
Googleドキュメントのクラス一覧
Googleフォームを編集する
function gaslog4_Form() {
// フォームクラスを用いて、IDを指定してファイルにアクセスする
let wForm = FormApp.openById('自分のGoogleフォームのIDを貼り付け');
// フォームに'がすぴょんについてどう思うか'の質問文を追加する
wForm.addParagraphTextItem().setTitle('がすぴょんについてどう思いますか')
.setRequired(true)
.setHelpText('できるだけ詳しく記載して下さい');
}
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
上記のプログラムを実行すると、対象フォームに質問「がすぴょんについてどう思いますか」がテキスト形式の必須回答項目として追加されます。
data:image/s3,"s3://crabby-images/54b1f/54b1fa4acfd0759901a004fd3bba90ed0270e037" alt=""
data:image/s3,"s3://crabby-images/54b1f/54b1fa4acfd0759901a004fd3bba90ed0270e037" alt=""
Googleドキュメントのクラス一覧
コンテナバインド型
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
コンテナバインド型にも簡単に触れたいと思います!
data:image/s3,"s3://crabby-images/7e472/7e47265038f03acf88415bad3ad9cabef6cdf828" alt=""
data:image/s3,"s3://crabby-images/7e472/7e47265038f03acf88415bad3ad9cabef6cdf828" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
「拡張機能」から「App Script」を選択するとエディタに遷移します!
function containerBind(){
//紐づくスプレッドシートを取得する
let ss = SpreadsheetApp.getActive();
//step1というシート名のシートを取得する
let sheetStep = ss.getSheetByName("step1");
//step1のB1セルを取得する
let rangeB1 = sheetStep.getRange(1,2);
//B1セルの値を取得する
let strB1 = rangeB1.getValue();
console.log(strB1);
}
data:image/s3,"s3://crabby-images/7b70e/7b70e15899a35ab1295f00210b68abb418c145f1" alt=""
data:image/s3,"s3://crabby-images/7b70e/7b70e15899a35ab1295f00210b68abb418c145f1" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
「▷実行」してみると、B1セルの情報を読み取ることができたね!
コードを1行で書くのは望ましくない
function containerBind(){
var ss = SpreadsheetApp.getActive().getSheetByName("step1").getRange(1,2).getValue();
console.log(ss);
}
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
data:image/s3,"s3://crabby-images/7ece3/7ece3c73bf166a8b869ace192abc9a11feacbc5b" alt=""
こんなカンジでコードを一行で書くのはダメなの?
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
data:image/s3,"s3://crabby-images/b6414/b6414f8d662ed073786675958250f51512cb5234" alt=""
同じコードを何度も記述しなくてはいけないし、メソッドを多用すると※使用制限がかかりやすくなってしまうんだ!同じ記述が続く場合は、変数を定義してあげて使いまわすことが大事だね!
まとめ
今回の記事では、Googleスプレッドシート
、Googleドキュメント
、Googleスライド
、Googleフォーム
について、簡単な操作方法を紹介しました!
次回以降では各クラス(特によく使われるGoogleスプレッドシートとGoogleフォームを重点的)の詳細な活用方法をどんどん記載していきますが、少しでも予習しておきたい方は以下から各クラスのリファレンスを学んでみてください!
Google スプレッドシートのクラス一覧
Googleドキュメントのクラス一覧
Googleスライドのクラス一覧
Googleフォームのクラス一覧
data:image/s3,"s3://crabby-images/d01fd/d01fd4f7bfe23fd3e6fd05fb1ed33f04debfb55b" alt=""
data:image/s3,"s3://crabby-images/d01fd/d01fd4f7bfe23fd3e6fd05fb1ed33f04debfb55b" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
data:image/s3,"s3://crabby-images/a7776/a777668cff52b92b661cfe07265d6bfcad2e9acd" alt=""
おかげさまで今年5月に起業しました!
GASやGoogleサービス、プログラミング全般のご相談承ります!
data:image/s3,"s3://crabby-images/28674/286741dc14167121661785cdf64236c5e471f2a6" alt=""
data:image/s3,"s3://crabby-images/28674/286741dc14167121661785cdf64236c5e471f2a6" alt=""
data:image/s3,"s3://crabby-images/28674/286741dc14167121661785cdf64236c5e471f2a6" alt=""
YouTubeでGoogleサービスをより
快適に使う方法をご紹介しています!
見て頂けたらうれしいです
コメント