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

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

ただいまの
回答率

90.01%

GAS getValue1つに時間がかかり過ぎる

受付中

回答 0

投稿

  • 評価
  • クリップ 2
  • VIEW 724

RIONFULE

score 4

前提・実現したいこと

宜しくお願いいたします。

現在、GASを使い、スプレッドシートの特定の列のセルの入力された(リストから選択された)値をもとに、その隣のセルにデータの入力規則を設定し、選択リストを表示できるようにするスクリプトを作成しています。
設定する処理自体は問題なく動作しているのですが、処理が完了するまでに7~10秒以上かかってしまっています。
リストが設定されるのを毎回10秒待つというのもなんだか馬鹿らしいので、どうにかしてこの処理時間を短くしてたいというのが今回実現したいことです。

どの処理に時間がかかっているのか調べたところ、冒頭部分に置いている「.getValue」1つにかかる時間が処理時間のほとんどを占めており、そのほかの処理については、それぞれ0,2秒もかかっていないようでした。

下記のコードでデータの入力規則の設定処理で使用しているgetValuesはここまで時間がかかっていないので、ダメもとでgetValuesに書き換えてみたところ、結果は変わりませんでした。

なお、今回のスクリプト内でgetValueを使用しているのはこの1箇所のみです。

質問したい点は、以下の2点です。

  1. 今回計測されているgetValueの処理時間は妥当なものか
    他のサイトで調べてみて、APIは時間がかかるのでできるだけ呼び出し使用回数を減らすことが高速化の手順の一つということを見てきたのですが、たった1つのgetValueにこんなにも時間がかかるものでしょうか。
    もし妥当でないようであれば、使い方や環境起因も考えなくてはならないのかなと思っています。

  2. getValueの使い方は妥当か
    初心者故にそもそものコードの書き方自体に問題があるかもしれませんので、もしお気づきの点がありましたらご教示頂けますと幸いです。

以上、よろしくお願いいたします。

該当のソースコード

function setDataValidation() {
  // 処理時間の確認
  Logger.log('データ入力規則設定処理の開始');
  var start = new Date();

  var spreadsheet = SpreadsheetApp.getActive();
  var sheet = spreadsheet.getActiveSheet();

  Logger.log('スプレッドシートの取得');

// シート名が特定のものの場合にのみ後続の処理を実行します
  if(sheet.getName() == 'A'){

    var getRan = new Date();
    var currentRange = spreadsheet.getActiveRange();
    var gotRan = new Date();
    Logger.log('currentRangeの取得に' + (gotRan-getRan)/1000 + '秒かかりました');


    var getVal = new Date();
    var currentValue = currentRange.getValue();
    var gotVal = new Date();
//    Logger.log('currentValueの取得:' + currentValue);
    Logger.log('currentValueの取得に' + (gotVal-getVal)/1000 + '秒かかりました');


// 入力規則の設定処理

Logger.log('全体の処理時間は' + (End-start)/1000 + '秒でした')
};

補足情報(実行時のログ)

[19-01-27 20:02:59:258 JST] データ入力規則設定処理の開始
[19-01-27 20:02:59:260 JST] スプレッドシートの取得
[19-01-27 20:02:59:334 JST] currentRangeの取得に0.001秒かかりました
[19-01-27 20:03:06:468 JST] currentValueの取得に7.133秒かかりました
[19-01-27 20:03:06:640 JST] 入力規則の設定に0.171秒かかりました
[19-01-27 20:03:06:641 JST] 全体の処理時間は7.381秒でした

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • macaron_xxx

    2019/01/28 18:42

    onEditトリガーにてリストより選択して関数を実行させましたが、getValueにそんなに時間がかかっていません。
    その他の条件などがわからないので、これ以上、調査不可です。

    キャンセル

  • 退会済みユーザー

    退会済みユーザー

    2019/01/29 21:08

    currentRangeが膨大な範囲になっているのでは?

    キャンセル

  • Cecco

    2019/02/12 17:07

    参考になるかわかりませんが、私の結果を貼っておきますね。
    それほど時間はかからないように思います。

    [19-02-12 17:05:36:553 JST] データ入力規則設定処理の開始
    [19-02-12 17:05:36:557 JST] スプレッドシートの取得
    [19-02-12 17:05:36:653 JST] currentRangeの取得に0.002秒かかりました
    [19-02-12 17:05:36:731 JST] currentValueの取得に0.077秒かかりました
    [19-02-12 17:05:36:731 JST] 全体の処理時間は0.177秒でした

    キャンセル

まだ回答がついていません

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

  • ただいまの回答率 90.01%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる