data:image/s3,"s3://crabby-images/d6fff/d6fff971a88f018105bee46e2ceb24ffabde29b2" alt="にほんブログ村 ブログブログ 雑記ブログへ"
にほんブログ村
こんにちは、わくほこ(@wakuhoko)です。
今回はGASを使ってスプレッドシートに値を書き込む方法をご紹介します。
具体的には、
- すでにあるスプレッドシートから値を取得し、別のスプレッドシートへ書き込む
という処理になります!
自分メモなので、もし「もっと良い方法があるよ!」などありましたら、ぜひ教えてください。
コードを書く前の準備
data:image/s3,"s3://crabby-images/6122c/6122c9c0594ec9329ad3397cf1d78f21fdae7269" alt="Linuxコマンドのメモ"
コードを書く前に事前に確認しておいて欲しい点が2点あります。
- GAS(Apps Script)の開き方
- 権限の確認
GASの開き方はこちらの記事を参考にしてみてください。
スプレッドシートの右上の「共有」ボタンからアカウントに編集権限を付与できます。
data:image/s3,"s3://crabby-images/fc5f9/fc5f9985588a64515b7b54f5cd939461ba50838f" alt="共有"
コードを書いてみよう!
それでは実際のコードです。
function myFunction() {
//書き込み先スプレッドシートの取得
const fileId = "書き込み先のスプレッドシートのID";
const fileObject = SpreadsheetApp.openById(fileId);
//書き込み先スプレッドシートのシート名を取得
const fileSheet = fileObject.getSheetByName("シート名");
//コピー元スプレッドシートのシート名を取得
const orgFile = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("コピー元シート名");
//値が存在するすべてのセルの値を取得
const orgData = orgFile.getDataRange().getValues();
//書き込み先スプレッドシートの1行目1列目から書き込み
fileSheet.getRange(1, 1, orgData.length, orgData[0].length).setValues(orgData);
}
コードの解説
data:image/s3,"s3://crabby-images/97efc/97efc800be0852360400634c5e94dcd728a8affe" alt="point"
まずは3行目のconst fileId = "書き込み先のスプレッドシートのID";
というコード。
これは値の書き込み先のシートidを取得しています。
“https://docs.google.com/spreadsheets/d/XXXXXXX/edit?hl=ja#gid=0″
スプレッドシートのURLの「XXXXXXX」の部分をコードの書き込み先のスプレッドシートのID
に入力してください。
4行目のSpreadsheetApp.openById(fileId);
では取得したidを元に書き込み先のスプレッドシートを指定して取得しています。
getSheetByName()
は引数にシート名を指定することで、シートを取得することができます。
例えば、「シート1」という名前のシートを取得したければ、getSheetByName("シート1");
となりますね!
data:image/s3,"s3://crabby-images/006b7/006b7e410cec8574e59a854d563af09c2f9df77a" alt="スプレッドシート"
data:image/s3,"s3://crabby-images/5bc07/5bc07ba0a7edd65699081a75893ae4348b8378c3" alt=""
余談ですが、スプレッドシートのシートってややこしいですよね…
SpreadsheetApp.getActiveSpreadsheet();
ではコピー元のスプレッドシートを取得しています。
.getSheetByName("コピー元シート名")
とすることでコピー元のスプレッドシートのシート名を指定することができます。
getActiveSpreadsheet()
は今開いているスプレッドシートとGASが紐づいている場合に使えるメソッドです。
orgFile.getDataRange().getValues();
では、getDataRange()
で値が存在する範囲を、getValues()
で指定した範囲の値を取得しています。
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
今回はコピー元のスプレッドシートから存在する値をすべて取得しています!
最後のgetRange(1, 1, orgData.length, orgData[0].length)
ではコピー元のスプレッドシートのどこからどこまでの値を取得するかを指定しています。
getRange(何行目の,何列目から,何行目の,何列分)
の値を取得するかを指定しています。
setValues();
は複数のセルに値を入力することができるメソッドです。
今回は引数にコピー元のスプレッドシートから取得した値を指定しています。
デバッグしてみよう!
data:image/s3,"s3://crabby-images/0e5b0/0e5b028dbc37c979145e454fa939db4e475d3f4f" alt="プログラミング"
data:image/s3,"s3://crabby-images/0e5b0/0e5b028dbc37c979145e454fa939db4e475d3f4f" alt="プログラミング"
せっかくなのでorgData.length
とorgData[0].length
の値を見てみましょう!
コピー元のスプレッドシートが以下のようになっているとします。
A列の1行目に「aaa」、A列の2行目に「bbb」という値が入っています。
data:image/s3,"s3://crabby-images/77229/77229e96f339922c2eefc0e3ddb44e57cbb4ffa6" alt="コピー元スプレッドシート"
data:image/s3,"s3://crabby-images/77229/77229e96f339922c2eefc0e3ddb44e57cbb4ffa6" alt="コピー元スプレッドシート"
//書き込み先スプレッドシートの1行目1列目から書き込み
fileSheet.getRange(1, 1, orgData.length, orgData[0].length).setValues(orgData);
Logger.log(orgData.length)
Logger.log(orgData[0].length)
コードの最終行に2行付け足してGASを実行します。
するとログに以下のように表示されます。
data:image/s3,"s3://crabby-images/d26f8/d26f84c2f10e1d995d910fb23614da9194cea959" alt="GASの実行ログ"
data:image/s3,"s3://crabby-images/d26f8/d26f84c2f10e1d995d910fb23614da9194cea959" alt="GASの実行ログ"
つまり、
getRange(1, 1, orgData.length, orgData[0].length)
はgetRange(1, 1, 2, 1)
と指定しているのと同じ意味になります。
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
data:image/s3,"s3://crabby-images/03e37/03e3701efb5c41db74f0856c95ee103e6b628fa7" alt=""
lengthを使うことでデータの数だけスプレッドシートに書き込むという指定をしているんですね!
data:image/s3,"s3://crabby-images/25197/2519783d7877a3f2e3bbf24bb2a44f55daa114f6" alt=""
data:image/s3,"s3://crabby-images/25197/2519783d7877a3f2e3bbf24bb2a44f55daa114f6" alt=""
data:image/s3,"s3://crabby-images/25197/2519783d7877a3f2e3bbf24bb2a44f55daa114f6" alt=""
getRange()メソッドで値を入力する範囲を指定して、setValues()メソッドで何の値を入力するかを指定しているってことか!
GASを実行してみよう!
data:image/s3,"s3://crabby-images/5a9b5/5a9b51897600f574db08b0877bb3cd87c0efa61f" alt="ノートPCと女性の手"
data:image/s3,"s3://crabby-images/5a9b5/5a9b51897600f574db08b0877bb3cd87c0efa61f" alt="ノートPCと女性の手"
さて、コードが書けたところでGASを実行してみましょう!
こちらの記事を参考にGASの「実行」ボタンを押します。
「権限を確認」ボタンを押します。
data:image/s3,"s3://crabby-images/eceff/eceff23d5303e92978dd0b21f8eb24e5d6722024" alt="承認"
data:image/s3,"s3://crabby-images/eceff/eceff23d5303e92978dd0b21f8eb24e5d6722024" alt="承認"
「アカウントの選択」で実行するアカウントを選択します。
data:image/s3,"s3://crabby-images/25da8/25da8f2f06e6deaef6839945fb64a9b58b0e1c75" alt="アカウントの選択"
data:image/s3,"s3://crabby-images/25da8/25da8f2f06e6deaef6839945fb64a9b58b0e1c75" alt="アカウントの選択"
もし以下のような画面が表示されたら、「詳細」をクリックしてください。
data:image/s3,"s3://crabby-images/97a1b/97a1b63bd8f7b19931f850c02168cbddc7ff8bf2" alt="Googleで確認されていません"
data:image/s3,"s3://crabby-images/97a1b/97a1b63bd8f7b19931f850c02168cbddc7ff8bf2" alt="Googleで確認されていません"
「安全ではないページに移動」を選択します。
data:image/s3,"s3://crabby-images/cbfe4/cbfe49a781d6fc8b8f3b508dbc3a2d8cfe34cada" alt="安全ではないページへ移動"
data:image/s3,"s3://crabby-images/cbfe4/cbfe49a781d6fc8b8f3b508dbc3a2d8cfe34cada" alt="安全ではないページへ移動"
アカウントへのアクセスを許可します。
data:image/s3,"s3://crabby-images/4499a/4499a6d09ce9c044e9cdf5c337ebb4df59ee0e69" alt="アクセス許可"
data:image/s3,"s3://crabby-images/4499a/4499a6d09ce9c044e9cdf5c337ebb4df59ee0e69" alt="アクセス許可"
これでGASが実行できるはずです!
data:image/s3,"s3://crabby-images/b887d/b887d420c454cbb47872f732be817bcdd58cd995" alt=""
data:image/s3,"s3://crabby-images/b887d/b887d420c454cbb47872f732be817bcdd58cd995" alt=""
data:image/s3,"s3://crabby-images/b887d/b887d420c454cbb47872f732be817bcdd58cd995" alt=""
コピー元のデータがコピー先のスプレッドシートに反映されていることを確認してみてくださいね!
おまけ:参考
わたしは最初に以下の本でGASを勉強しました!
正直、調べながら実際にコードを書くのが1番勉強になります。
が、「GASって何ぞや??」というところから詳しく解説されているので理解が深まります◎
終わりに
今回はGASですでにあるスプレッドシートから値を取得し、別のスプレッドシートへ書き込む方法をご紹介しました!
setValues()
メソッドがめちゃくちゃ便利だなと思いました。
以前書いた以下の記事もsetValuesメソッドでリファクタリングできそうな気がします。
まあ、それはおいおいということで…
今回の記事がどなたかの参考になれば幸いです!
以下ではGASでGmailに届いた問い合わせを自動でスプレッドシートに転記する方法をご紹介しています。
data:image/s3,"s3://crabby-images/f4366/f4366fc0fd568ae5b1055a93333d6f14a74e101d" alt=""
data:image/s3,"s3://crabby-images/f4366/f4366fc0fd568ae5b1055a93333d6f14a74e101d" alt=""
また、スプレッドシートの関数を使って動的に値を表示させる方法もご紹介しています。
こちらもよければ参考にしてみてください!
ではでは〜
data:image/s3,"s3://crabby-images/d6fff/d6fff971a88f018105bee46e2ceb24ffabde29b2" alt="にほんブログ村 ブログブログ 雑記ブログへ"
data:image/s3,"s3://crabby-images/d6fff/d6fff971a88f018105bee46e2ceb24ffabde29b2" alt="にほんブログ村 ブログブログ 雑記ブログへ"
にほんブログ村