質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

4560閲覧

Google Apps ScriptのAPIのリクエスト回数を減らす方法

SASAKI_APPL

総合スコア100

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

2クリップ

投稿2016/06/03 16:06

GoogleスプレッドシートのGASを使っています。

本当に基礎的な質問です。
for文の中にあるAPIのリクエストを減らす(外に出す)方法を教えてください。

JavaScript

1 var tt = sheet.getRange( lastRow, 4 ).getValue(); 2 for ( i = lastRow+value2 ; i > 2 ; i-- ){ //2〜最終行までループ 3 4 var tmp = sheet.getRange(searchRow + i ).getValue(); //セルの値取得 5 var ttm = sheet.getRange(searchRow + i );//セルの範囲を取得 6 if( targetString == tmp ){ 7 8 var tt = ttm.offset(0, 1).getValue(); 9 10 var range2 = sheet.getRange( lastRow, 4 ); 11 12 range2.setValue(range7);// 13 14 } 15 }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

雰囲気はこんな感じです。

JavaScript

1function myFunction() { 2 var range = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getRange( 1,1,4,10 ); 3 var data = range.getValues(); 4 for( var i=0; i<4; i++ ){ 5 for( var j=0; j<10; j++ ){ 6 data[i][j] = "i="+i+":J="+j; 7 } 8 } 9 range.setValues(data); 10}

例えば上記の例だと40個のセルにアクセスしているのに、APIリクエスト数は以下の5回だけだと思います。

  • getActiveSpreadsheet()
  • getActiveSheet()
  • getRange( 1,1,4,10 )
  • getValues()
  • setValues(data)

投稿2017/01/30 16:14

hikochang

総合スコア648

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

SASAKI_APPL

2017/01/31 15:33 編集

実行してみて理解できました。ありがとうございます。
guest

0

ベストアンサー

処理対象の範囲を range.getValues(); で一気に受け取り、配列を適切に書き換え、range.setValues(values); で一気に戻すといいと思います。

リファレンス:.getValues()
リファレンス:.setValues(values)

投稿2016/06/03 16:28

kei344

総合スコア69398

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

SASAKI_APPL

2016/06/04 06:11

ごめんなさい。もう少し詳しいコードを教えていただけないでしょうか? var tmp = sheet.getRange(searchRow + i ).getValue(); //セルの値取得 var ttm = sheet.getRange(searchRow + i );//セルの範囲を取得 このコードをfor文の上に出せばいいということでしょうか?
kei344

2016/06/04 06:33

for の中に有る getValue setValue getRange を全て外に出すということです。 .getValue() と .getValues() では取得するデータ範囲が違います。.getValues() では 「[ [ 1, 2, 3, 4 ], [ 1, 2, 3, 4 ], [ 1, 2, 3, 4 ], [ 1, 2, 3, 4 ] ] 」のような二次元配列が返ってくるので、それの必要な部分を for などでアクセスして変更し、.setValues(values) で書き換えればどうでしょう、ということです。
SASAKI_APPL

2016/06/08 11:55

再び回答ありがとうございます。 返信遅くなってしまい、すみません。 二次元配列がまだよくわかりません。 ですが、何が必要なのかわかったような気がします。 もう少し勉強してからもう一度質問を投稿しようと思います。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問