ホームページ >ウェブフロントエンド >jsチュートリアル >Google Apps Script が非常に遅いのはなぜですか? `getValues` と `setValues` の使用を最適化するにはどうすればよいですか?

Google Apps Script が非常に遅いのはなぜですか? `getValues` と `setValues` の使用を最適化するにはどうすればよいですか?

DDD
DDDオリジナル
2024-12-01 03:05:14808ブラウズ

Why is my Google Apps Script so slow, and how can I optimize `getValues` and `setValues` usage?

getValues と setValues の過剰な使用による長い処理時間

問題:

コードでは getValues メソッドと setValues メソッドの過剰な使用が問題となり、処理に重大な影響を与える可能性があります。

最適化テクニック:

サービスコールの最小化:

  • 不必要なサービスコールを避けるGoogle Apps Script サービスの呼び出し。代わりに、データをローカルにキャッシュし、スクリプト内で操作します。

先読みキャッシュ:

  • Google Apps Script は組み込みの Look を採用しています。 -ahead キャッシュにより、可能性のあるデータを取得します。

読み取り/書き込み操作を最小限に抑える:

  • 配列内のデータを取得して操作することで、読み取りおよび書き込み操作をバッチ処理します。これにより、サーバーへの呼び出しの数が減少します。

交互の読み取り/書き込みを避ける:

  • 読み取りコマンドと書き込みコマンドを交互に実行すると、先読みキャッシュが中断されます。 。この交互パターンを最小限に抑えるように操作を計画してください。

配列の使用:

  • 配列を使用してデータを効率的に保存します。 1 回の getValues 呼び出しですべてのデータを配列に取得し、操作を実行してから、1 回の setValues 呼び出しでそれを書き戻します。

例:

次のコード スニペットを考えてみましょう:

// Slow version: Alternating read and write operations
const sourceRange = SpreadsheetApp.getActiveSheet().getRange("A1:D2");
const targetRange = sourceRange.offset(2, 0);
for (let i = 0; i < sourceRange.getNumRows(); i++) {
  for (let j = 0; j < sourceRange.getNumColumns(); j++) {
    const value = sourceRange.getCell(i + 1, j + 1).getValue();
    targetRange.getCell(i + 1, j + 1).setValue(value);
  }
}

// Fast version: Batch read and write operations
const sourceValues = sourceRange.getValues();
targetRange.setValues(sourceValues);

読み取りおよび書き込み操作をバッチ処理することで、2 番目のコード スニペットがサービスへの呼び出し数が大幅に削減され、処理時間が短縮されます。

以上がGoogle Apps Script が非常に遅いのはなぜですか? `getValues` と `setValues` の使用を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。